WO2020018704A1 - Réseau central défini par logiciel haute performance - Google Patents

Réseau central défini par logiciel haute performance Download PDF

Info

Publication number
WO2020018704A1
WO2020018704A1 PCT/US2019/042261 US2019042261W WO2020018704A1 WO 2020018704 A1 WO2020018704 A1 WO 2020018704A1 US 2019042261 W US2019042261 W US 2019042261W WO 2020018704 A1 WO2020018704 A1 WO 2020018704A1
Authority
WO
WIPO (PCT)
Prior art keywords
network
tenant
routing
configuring
data
Prior art date
Application number
PCT/US2019/042261
Other languages
English (en)
Inventor
Nithin MICHAEL
Ao Tang
Victor De Souza Lima E SILVA
Thiago Sousa SANTOS
Ning Wu
Archit BAWEJA
Ki Suh LEE
Yao Wang
Andrey GUSHCHIN
Sakethnath ARE
Original Assignee
The Mode Group
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US16/164,457 external-priority patent/US20200036624A1/en
Priority claimed from US16/189,735 external-priority patent/US20190238450A1/en
Priority claimed from US16/188,740 external-priority patent/US20190238449A1/en
Priority claimed from US16/207,156 external-priority patent/US11252079B2/en
Priority claimed from US16/207,155 external-priority patent/US20200296026A1/en
Priority claimed from US16/227,949 external-priority patent/US20190280962A1/en
Priority claimed from US16/227,967 external-priority patent/US20190280963A1/en
Priority claimed from US16/231,527 external-priority patent/US10992568B2/en
Priority claimed from US16/231,532 external-priority patent/US20200021515A1/en
Priority claimed from US16/231,530 external-priority patent/US20200021514A1/en
Priority claimed from US16/231,529 external-priority patent/US20190280964A1/en
Priority claimed from US16/378,712 external-priority patent/US20190372889A1/en
Priority claimed from US16/378,689 external-priority patent/US11121962B2/en
Priority claimed from US16/378,771 external-priority patent/US20200106696A1/en
Priority to EP19838906.6A priority Critical patent/EP3824603A4/fr
Application filed by The Mode Group filed Critical The Mode Group
Publication of WO2020018704A1 publication Critical patent/WO2020018704A1/fr

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/08Configuration management of networks or network elements
    • H04L41/0803Configuration setting
    • H04L41/0823Configuration setting characterised by the purposes of a change of settings, e.g. optimising configuration for enhancing reliability
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/08Configuration management of networks or network elements
    • H04L41/0803Configuration setting
    • H04L41/0806Configuration setting for initial configuration or provisioning, e.g. plug-and-play
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/08Configuration management of networks or network elements
    • H04L41/0895Configuration of virtualised networks or elements, e.g. virtualised network function or OpenFlow elements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/12Discovery or management of network topologies
    • H04L41/122Discovery or management of network topologies of virtualised topologies, e.g. software-defined networks [SDN] or network function virtualisation [NFV]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/40Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks using virtualisation of network functions or resources, e.g. SDN or NFV entities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/20Arrangements for monitoring or testing data switching networks the monitoring system or the monitored elements being virtualised, abstracted or software-defined entities, e.g. SDN or NFV
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/12Shortest path evaluation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/12Shortest path evaluation
    • H04L45/121Shortest path evaluation by minimising delays
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/12Shortest path evaluation
    • H04L45/123Evaluation of link metrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/12Shortest path evaluation
    • H04L45/124Shortest path evaluation using a combination of metrics
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/12Shortest path evaluation
    • H04L45/125Shortest path evaluation based on throughput or bandwidth
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/24Multipath
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/64Routing or path finding of packets in data switching networks using an overlay routing layer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/12Avoiding congestion; Recovering from congestion
    • H04L47/125Avoiding congestion; Recovering from congestion by balancing the load, e.g. traffic engineering
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/10Active monitoring, e.g. heartbeat, ping or trace-route

Definitions

  • the embodiments herein relate to networking and, more particularly, to core networks that complement enterprise network deployments to provide the highest levels of network performance.
  • Enterprise applications are moving to a cloud-based environment, referred to herein as the cloud.
  • the dynamic nature of such applications e.g., Infrastructure as a Service (IaaS), Platform as a Service (PaaS), Software as a Service (SaaS), Unified Communications as a Service (UCaaS), etc.
  • IaaS Infrastructure as a Service
  • PaaS Platform as a Service
  • SaaS Software as a Service
  • UaaS Unified Communications as a Service
  • Hardware-defined private networks e.g., MPLS
  • MPLS while being very reliable, are complex, inflexible and costly. Therefore, many enterprises currently bear the burden of managing multiple networks, because no single network offers the adequate combination of reliability, cloud flexibility, and internet affordability. Enterprises therefore need an improved core network alternative.
  • FIG 1 is an example block diagram of the Mode Core Network (MCN) overlay network, under an embodiment.
  • MCN Mode Core Network
  • FIG. 2A is a block diagram of MCN components, under an embodiment.
  • FIG. 2B is a block diagram of MCN components and their couplings or connections to the public Internet and other POPs (Points of Presence) of the MCN, under an embodiment.
  • POPs Points of Presence
  • Figure 3 is a block diagram of an example composite network 300 including the MCN components of the overlay network 301-334 provisioned over an underlay network 399 (collectively 399-1, 399-2, 399-3), under an embodiment.
  • Figure 4 is a block diagram of an example multi-cloud configuration including components of the MCN, under an embodiment.
  • FIG. 5 is a block diagram showing components of a POP, under an
  • Figure 6 is a flow diagram for operations of the Dolfin, under an embodiment.
  • FIG. 7 is a flow diagram for operations of the Watchdog, under an
  • Figure 8 is a flow diagram for log in and authentication of the MCN, under an embodiment.
  • Figure 9 is a flow diagram showing components and information flow for onboarding a new client, under an embodiment.
  • Figure 10 is a flow diagram showing components and information flow for creating and inviting other uses in an enterprise, under an embodiment.
  • Figure 11 is a flow diagram for an authentication of Bouncer including use of tokens, under an embodiment.
  • Figure 12 is a flow diagram for network provisioning, under an embodiment.
  • Figure 13 is a flow diagram of a provisioning example, under an embodiment.
  • Figure 14 is a flow diagram for configuring a network including setting up a route, under an embodiment.
  • Figure 15 is a flow diagram for a traffic flow example using DNS redirection, under an embodiment.
  • Figure 16 is a flow diagram for removing network configuration data and removing routes, under an embodiment, under an embodiment.
  • Figure 17 is a flow diagram for releasing an existing network, under an embodiment, under an embodiment.
  • Figures 18A and 18B (collectively referred to herein as Figure 18) show a block diagram of the provisioner database structure comprising numerous tables, under an embodiment.
  • Figure 19 is a block diagram of a POP, under an embodiment.
  • Figure 20 is a block diagram of an aggregator, under an embodiment.
  • Figure 21 is a block diagram of example aggregator couplings or connections, under an embodiment.
  • Figure 22 is a block diagram showing probing operations of Orca, under an embodiment.
  • Figure 23 is a block diagram showing an example determination of a designated egress POP, under an embodiment.
  • Figure 24 is a block diagram showing an example determination of a new egress POP in response to failure of a current egress POP, under an embodiment.
  • Figure 25 is a block diagram of an example traffic routing using address translation by Orcas at the ingress and egress POPs, under an embodiment.
  • Figure 26 is a block diagram showing Orca components, under an embodiment.
  • Figure 27 is a flow diagram of communications between Orca and other MCN components, under an embodiment.
  • FIG. 28 is a block diagram showing POPs (e.g., S1-S4) coupled to
  • an upstream (e.g., tenant) router communicate with an upstream (e.g., tenant) router, under an embodiment.
  • upstream e.g., tenant
  • Figure 29 is a block diagram showing Orca comprising routing software (e.g., Quagga) coupled to communicate with the MCN and a tenant router, under an embodiment.
  • routing software e.g., Quagga
  • Figure 30A is a flow diagram of communications between Dolfin and other MCN components, under an embodiment.
  • Figure 30B shows a POP configuration including Sardine, under an embodiment.
  • Figure 30C shows information flows involving the OVS bridge, Dolfin, and Sardine, under an embodiment.
  • Figure 31 is a flow diagram of link discovery by Dolfins to discover ingress and egress links to neighbor Dolfins, under an embodiment.
  • Figure 32 shows route advertisement among Dolfins, under an embodiment.
  • Figure 33 shows link property advertisement among Dolfins, under an embodiment.
  • Figure 34 is an example rule tree, under an embodiment.
  • Figure 35 is an example rule tree, under an embodiment.
  • Figure 36 is a block diagram showing Dolfin components involved in loop avoidance, under an embodiment.
  • Figure 37 is an example involving node value calculation in a portion of the core network, under an embodiment.
  • Figure 38 is a flow diagram for monitoring parameters of the MCN, under an embodiment.
  • Figure 39 is a block diagram showing Dolfins and corresponding Watchdogs in an example portion of the core network, under an embodiment.
  • Figure 40 is a block diagram of the central monitoring, under an embodiment.
  • Figure 41 is a flow diagram for system health checks, under an embodiment.
  • Figure 42 shows a flow example involving a hierarchy for selecting a dashboard, under an embodiment.
  • Figure 43 shows a flow example involving a hierarchy for selecting another dashboard, under an embodiment.
  • Figure 44 is a flow diagram for updating dashboards, under an embodiment.
  • Figure 45 is a block diagram of the management plane, under an embodiment.
  • Figure 46 is a block diagram showing a high availability configuration involving replicated tenant stacks at a POP, under an embodiment.
  • Figure 47 is a block diagram showing an example high availability configuration involving the data plane of a portion of the MCN, under an embodiment.
  • Figure 48 is a flow diagram showing, under an embodiment.
  • Figure 49 is a flow diagram showing egress routes when all POPs of the MCN are configured as egress POPs, under an embodiment.
  • Figure 50 illustrates an example of a network.
  • Figure 51A illustrates an example of a network having two nodes according to the present invention.
  • Figure 51B illustrates an example of a network having three nodes according to the present invention.
  • Figure 51C illustrates another example of a network having three nodes according to the present invention.
  • Figure 51D illustrates an example of a network having a plurality of nodes according to the present invention.
  • Figure 52 illustrates a comparison of an embodiment of the present invention with Gallager’s distance- vector approach known in the art.
  • Figure 53 illustrates a best (shortest) path tree in a network along with a branch of that tree highlighted.
  • Figure 54A illustrates an example of a network according to the present invention.
  • Figure 54B illustrates a comparison of solutions provided by different procedures seeking to identify the optimal solution to a network routing problem.
  • Figure 55 illustrates an Abilene network.
  • Figure 56A illustrates a comparison of the optimality gap between an
  • Figure 56B illustrates a comparison of the optimality gap between an
  • Figure 56C illustrates a comparison of the optimality gap between an
  • Figure 57A illustrates a comparison of the optimality gap between an
  • Figure 57B illustrates a comparison of the optimality gap between an
  • Figure 57C illustrates a comparison of the optimality gap between an
  • Figure 58 A illustrates a comparison of the optimal performance and an embodiment of the present invention in the Abilene network.
  • Figure 58B illustrates a comparison of the optimal performance and an embodiment of the present invention in a 4 x 4 mesh network.
  • Figure 58C illustrates a comparison of the optimal performance and an embodiment of the present invention in a hierarchical 50 node network.
  • Figure 59 A illustrates a comparison of a known procedure (OSPF with optimized link weights) and an embodiment of the present invention in the Abilene network.
  • Figure 59B illustrates a comparison of a known procedure (OSPF with optimized link weights) and an embodiment of the present invention in a 4 x 4 mesh network.
  • Figure 59C illustrates a comparison of a known procedure (OSPF with optimized link weights) and an embodiment of the present invention in a hierarchical 50 node network.
  • Figure 60A illustrates the evolution of optimality gap for the Abilene network as the number of iterations increase with varying demand matrices.
  • Figure 60B illustrates evolution of split ratios to Chicago, Kansas City and Atlanta for traffic destined to LA at the Indianapolis node in Abilene network.
  • Figure 61 illustrates evolution of the optimality gap for a randomly generated 100 node network with varying step-sizes.
  • Figure 63 illustrates a network embodiment of the present invention.
  • Figure 64 illustrates another network embodiment of the present invention.
  • Figure 65 illustrates the evolution of the split ratios at a node in the network.
  • Figure 66 illustrates the evolution of the split ratios at a node in the network in presence of additional short-term traffic variations.
  • Figure 67 illustrates an exemplary computer system.
  • Figure 68 illustrates an exemplary cloud computing system.
  • bandwidth includes the count of bits per second across a defined interface point, such as a link.
  • bandwidth is the product of the packets per second and the bits per packet.
  • capacity includes the maximum bandwidth across a defined interface point, such as a link.
  • control plane includes the collection of components within the MCN that compose the rules related to the delivery of packets from POP to POP.
  • Control plane may refer to the components within a single overlay network, or across multiple overlay networks depending on the context.
  • customer includes an entity (e.g., enterprise, multi- service provider (MSP), etc.) that is billed for MCN services and controls one or more tenant networks.
  • entity e.g., enterprise, multi- service provider (MSP), etc.
  • MSP multi- service provider
  • data plane includes the collection of components within the MCN that directly handle packet forwarding and delivery based on the rules provided by the control plane.
  • Data plane may refer to the components with a single overlay network or across multiple overlay networks depending on the context.
  • egress destination includes that portion of a route that enables tenant traffic be delivered from the MCN to the correct location (e.g., an egress destination is typically tied to an egress POP).
  • encapsulation includes the process of adding headers to a packet in order to have it processed or forwarded by network entities in a specific way.
  • Decapsulation is the process of removing the headers added during encapsulation so that the original packet is restored.
  • GRE, IPsec tunnel mode, and VxLAN are all protocols that perform encapsulation.
  • routing attractor includes that portion of a route that enables tenant traffic to arrive at the MCN (TIPs and VIPs are examples of ingress attractors).
  • jitter includes the measure of latency variation within a single flow or probing system.
  • latency includes the measure of the time delay between when a packet is sent from one point and when it is received at another point.
  • latency variation includes the change in the latency between two points over time.
  • link also referred to as“network link”, as used herein includes a physical means of connectivity between two locations (e.g., POPs).
  • link state includes a numerical description of the state of a link.
  • management plane includes the collection of components within the MCN that handle provisioning of control planes and data planes, collecting network statistics, and providing a user interface for customers and tenants.
  • the MCN of an embodiment include one management plane but is not so limited.
  • MCN MODE Core Network
  • MSP managed service provider
  • overlay network includes a set of components that provide connectivity between POPs such that packets can be identified separately from those on other overlay networks using the same underlay network.
  • POP Point of Presence
  • RTT Random-Trip Time
  • route includes a tenant-controlled service that specifies one or more ingress attractors and egress destinations.
  • route destination includes an egress destination without any indication of the specific egress POP.
  • routing includes the process of selecting among two or more pathways for the item(s) to travel through the network.
  • site administrator or“site admin” as used herein includes a user role that gives permission for someone to manage all aspects of the MCN.
  • split ratio includes selection of which packets or how many packets follow which path through which nodes of the network.
  • tenant includes the entity that controls one or more routes in a tenant network.
  • the term“tenant network”, also referred to as“network”, as used herein includes an entity whose network traffic is isolated and tracked in aggregate for management, reporting and billing an MCN customer.
  • the term“traffic” as used herein includes IP packets that arrive from or are delivered to the Internet and potentially traverse the MCN.
  • the term“underlay network” as used herein includes a set of components and links that provide connectivity between POPs such that packets can be delivered from one POP to another and potentially to/from the Internet.
  • utilization includes the ratio of the current bandwidth to the capacity across a defined interface point, such as a link.
  • virtual gateway also referred to as“Orca”, as used herein includes a gateway controller configured per-tenant, per-network, per-route with ingress attractions, ingress bandwidth limitations, and valid egress destinations. Orca identifies per-tenant, per-network, per-route, per-flow packets and the associated egress destination, and isolates and forwards packets according to the identified parameters.
  • VIP Virtual IP address
  • virtual isolation includes isolation between tenant networks that prevents modification of packet identification by a third party while packets are en route across the network.
  • virtual link includes virtual connectivity (layer 2) between POPs configured as a component of the overlay network and uses the underlay links for packet delivery.
  • virtual router also referred to as“Dolfin”, as used herein includes a controller configured to identify per-tenant, per-network, per-route, per-traffic class, per- flow packets and the associated objective functions, and forward the packets based on the objective function to the correct/best virtual link for delivery to an egress destination. Dolfin is also configured to receive per-link metrics or statistics and state for use with the objective functions.
  • the term“virtual watchdog”, also referred to as“Watchdog”, as used herein includes a monitoring agent configured to measure per-virtual link statistics, determine link status for all virtual links in a POP, monitor health of Dolfins, deliver data of link statistics to Dolfin, and deliver data of Dolfin health to other MCN components.
  • Embodiments described herein provide a software-defined core network (SD- CORE) configuration that brings the value of software-defined infrastructure to the network core.
  • SD-CORE referred to herein as Mode Core Network (MCN)
  • MCN Mode Core Network
  • the MCN includes a global overlay, over other networks, which comprises an edge compute network formed in partnership with multiple service providers.
  • the MCN is configured for side-by-side use with MPLS and Internet to realize an autonomous private backbone that complements any enterprise Software Defined Wide Area Network (SD-WAN) deployment while remaining affordable.
  • SD-WAN Wide Area Network
  • the MCN includes routing algorithms that automate traffic routing on each node of the network.
  • the routing algorithms are based on a novel characterization of network traffic dynamics in mathematical terms that includes the use of characteristic equations to define traffic flows in packet-switched networks.
  • the majority of performance degradation such as latency variance in Internet traffic happens in the core, so the MCN changes networking by using the math-based algorithms to replace traditional routing at layers 2 and 3 of the Open Systems Interconnection (OSI) model, and in so doing delivers the theoretical limit of high performance.
  • OSI Open Systems Interconnection
  • the MCN is configured to provide closed-loop control for packet-switched networks that quickly adapts to dynamic traffic changes (e.g., jitter, latency, cost, utilization, etc.) without prior knowledge by
  • the routing efficiency enabled by the MCN therefore provides an affordable SD-CORE for cloud access, remote access, site-to-site, SD-WAN, Unified Communications (UC), UC as a service (UCaaS), Iaas, Paas, SaaS, and ultra low latency (ULL) applications, to name a few.
  • UCaaS Unified Communications
  • Iaas Iaas
  • Paas Paas
  • SaaS ultra low latency
  • Embodiments of the MCN described herein include systems and methods for global control and optimization of data traffic through or in networks including software- defined networks.
  • the MCN comprises numerous nodes placed in data centers across the world and interconnected using private leased lines to form an overlay network that overlays another network (e.g., public network, private network in the form of private leased lines, etc.), referred to herein as an“underlay network”.
  • Components of the MCN are strategically placed in the best locations to provide connectivity to tenants and service application providers across the world.
  • the cloud acceleration realized with use of the MCN provides seamless, accelerated connectivity to tenants from any location, including branch offices and/or distributed or remote locations.
  • the term“tenant” as used herein includes enterprises, clients, customers, and corresponding sites and service applications, to name a few, but is not so limited as it includes all entities and persons using the MCN for routing data traffic.
  • Each node of the MCN is configured to host a number of virtual machines (VMs), and the MCN optimizes the flow of data traffic in a wide area network (WAN) by configuring the VMs to provide alternate routing in addition to the conventional routing of the underlay network provider.
  • a node running the VMs is referred to herein as a point of presence (POP) server, or POP, and each POP supports traffic of multiple tenants using computing elements dedicated to each tenant.
  • POPs point of presence
  • the system of POPs is configured to manage or control data flow by routing data between data origination and destination points via the overlay and underlay networks as described in detail herein.
  • the MCN includes unique routing algorithms configured to virtualize the network and use multi-path routing of data traffic, thereby providing the best application experience for cloud connectivity at a relatively lower price.
  • the improved experience of these embodiments includes but is not limited to more reliable and consistent throughput, improved network metrics (e.g., latency, jitter, packet loss, throughput, utilization, etc.), unified policy management and accessibility from a remote location, and geographical redundancy and/or independence for access to cloud resources.
  • the routing algorithms of the MCN are configured to control routing of traffic flows on a hop-by-hop basis by determining at each node a“least cost” path for the next hop.
  • the lowest cost path is determined based on one or more link metrics such as packet loss, jitter, latency, throughput, and utilization as described herein.
  • Traffic routing is then continuously and iteratively adjusted throughout the network, including when the input traffic pattern and network state are not changing.
  • the routing algorithms adjust or reroute traffic as the system iteratively adjusts traffic routes to track the optimal operating point for the network, but is not so limited.
  • the MCN is configured to provide optimization for all applications accessed via the MCN, irrespective of the tenant location from which the MCN is accessed.
  • the connectivity to such service applications is seamless to users, so they are not required to change the way in which they currently access the service applications, and yet be able to get the best possible user experience accessing such resources (e.g., IaaS, PaaS, SaaS, UCaaS, etc.).
  • FIG. 1 is an example block diagram of the MCN overlay network, under an embodiment.
  • the overlay network includes a number of POPs coupled to
  • each POP of an embodiment is configured to support multiple tenants.
  • Each POP generally includes multiple sets of VMs as described herein, and each set of VMs instantiates a set of MCN components configured to correspond to and support a tenant of the POP.
  • Each set of MCN components is configured to control the routing of traffic of its corresponding tenant via the overlay network and utilizing links of the underlay network.
  • the couplings to each POP comprise the couplings or connections (e.g., Internet) from/to the corresponding tenants.
  • the couplings of each POP, which couples or connects to all other POPs of the overlay network, also include virtual links comprising multiple independent tunnels, each of which corresponds to a tenant supported by the POP. Routing of data traffic via the network therefore generally involves receiving input data at an ingress POP, also referred to as an ingress attractor, from a corresponding originating tenant or source, routing the data via the network to an egress POP, and sending the data from the egress POP over a last mile connection to the egress destination that corresponds to the intended recipient of the data.
  • an ingress POP also referred to as an ingress attractor
  • Each POP includes a set of computing elements corresponding to each tenant, and each set of computing elements includes instances of a set of MCN components configured to support a corresponding tenant of the POP.
  • Figure 2A is a block diagram of MCN components, under an embodiment.
  • Figure 2B is a block diagram of MCN components and their couplings or connections to the public Internet and other POPs (virtual links) of the MCN, under an embodiment.
  • the MCN components include multiple sets of VMs deployed per tenant at each POP, and each set of VMs instantiates a set of MCN components comprising one or more instances (per tenant) of an Orca, Dolfin, Watchdog, and Open Virtual Switch (OVS).
  • OVS Open Virtual Switch
  • Orca functions as a gateway controller (“virtual gateway”) for ingress/egress traffic of a tenant to/from the MCN via the public Internet.
  • Dolfin is configured as the controller (“virtual router”) that, along with the OVS and corresponding flow rules, routes traffic to/from other POPs of the MCN via the virtual links.
  • Watchdog (“virtual Watchdog”) is configured as a monitoring agent to collect link metrics of the virtual links of the MCN.
  • the MCN components include components that form the management plane of the MCN.
  • the management plane components which are coupled to the MCN components of the POPs, include but are not limited to tenant-facing web user interfaces (UIs) (WEB-UIs), the web application (WEB-APP), a Bouncer configured for role-based user access, and a provisioner configured to manage configurations of the MCN components as well as other network resources.
  • the MCN also includes components configured for monitoring the health of MCN components and logging data of the monitoring (not shown), along with data stores configured to support the MCN components, as described in detail herein.
  • the MCN comprises numerous POPs provisioned as an overlay onto an underlay network as described herein.
  • Figure 3 is a block diagram of an example composite network 300 including the MCN components of the overlay network 301-334
  • underlay network 399 provisioned over an underlay network 399 (collectively 399-1, 399-2, 399-3), under an embodiment.
  • the overlay network is independent from the underlay network, and is configurable to operate with any type of underlay network.
  • the underlay network 399 of this example comprises a network including network nodes 399-1, 399-2, 399-3 provided by a corresponding ISP as described herein. While the underlay network 399 is represented in this example as including three nodes for purposes of clarity, it is understood that the underlay network 399 includes numerous nodes, routers, and other network components and resources not shown.
  • the overlay network of this example includes three POPs 311, 321, 331 coupled to intercommunicate to form the MCN.
  • each POP includes two VMs provisioned over the underlay components, and each VM is configured to control the routing of data traffic of its corresponding tenant.
  • a first VM at each POP is dedicated to tenant A and is configured to route data of tenant A exclusively between enterprise locations of tenant A (not shown).
  • a second VM is dedicated to tenant B and is configured to route data of tenant B exclusively between enterprise locations of tenant B (not shown).
  • POP 311 includes VM 311 A supporting tenant A and VM 311B supporting tenant B
  • POP 321 includes VM 321 A supporting tenant A and VM 321B supporting tenant B
  • POP 331 includes VM 331 A supporting tenant A and VM 331B supporting tenant B.
  • the overlay network is further configured to include a dedicated tunnel or virtual link between each VM of a tenant to provide virtual isolation between tenant networks, such that the combination of the VM components and their respective tunnel support multi-tenancy by maintaining separation of multi-tenant traffic throughout the network 300. Therefore, in this example, tunnel 301 A supports traffic routed between tenant A VMs 311 A, 321 A, 331 A, and tunnel 301B supports traffic routed between tenant B VMs 311B, 321B, 331B.
  • the number of tenants supported with the overlay network is horizontally scalable by increasing a number of VM instances at a POP, and each tenant is configured to access each POP using its own IP addresses.
  • the MCN is configured as a multi-tenant network and therefore includes multiple independent tunnels (e.g., Virtual Extensible Local Area Network (VXLAN)) to separate the traffic between different entities.
  • VXLAN Virtual Extensible Local Area Network
  • the MCN is configured to isolate the control plane and data plane of each tenant.
  • the MCN is also configured to optimize data routing and dynamically adapt routes per-tenant, per- hop based on link conditions.
  • the VM corresponding to each tenant generally comprises an Orca, a Dolfin, and an aggregator configured to control the routing of traffic of that tenant. Therefore, in this example, the tenant A VM 311 A at POP 311 includes an Orca 312 A, a Dolfin 313 A, and an aggregator 314 A, and the tenant B VM 311B at POP 311 includes an Orca 312B, a Dolfin 313B, and an aggregator 314B.
  • the tenant A VM 321 A at POP 321 includes an Orca 322A, a Dolfin 323 A, and an aggregator 324A
  • the tenant B VM 321B at POP 321 includes an Orca 322B, a Dolfin 323B, and an aggregator 324B
  • the tenant A VM 331 A at POP 331 includes an Orca 332A, a Dolfin 333 A, and an aggregator 334 A
  • the tenant B VM 331B at POP 331 includes an Orca 332B, a Dolfin 333B, and an aggregator 334B. While each of the Orca, Dolfin, and aggregator are described in a general manner for purposes of clarity in this example, it is understood that each POP includes additional components per tenant as described in detail herein.
  • the Orca which is configured as a gateway controller, is coupled to a corresponding tenant via a WAN or public Internet.
  • the Orca is further coupled to the Dolfin via the aggregator as described in detail herein.
  • the Orca is configured to attract traffic to the MCN from tenants, and to operate as a virtual gateway for that incoming traffic.
  • Each Dolfin which is configured as a routing controller or virtual router, is coupled to other POPs of the MCN via the corresponding aggregator and a tenant tunnel of the underlay that corresponds to the tenant supported by the Dolfin. Incoming traffic from a tenant is received at the Orca, and then classified by the corresponding Dolfin.
  • identified traffic is routed under control of the corresponding Dolfin to the aggregator where it is placed into the corresponding tenant tunnel.
  • Traffic addressed to the tenant arriving at the egress POP via the tenant tunnel is routed to the corresponding Orca via the aggregator, and the Orca is configured to send the traffic over the WAN“last mile” coupling or connection to the tenant.
  • the Dolfin corresponding to a tenant is configured to route the data traffic of that tenant using network information including the network topology data and the link cost data (function of link performance metrics such as utilization or latency). This network information is obtained using control traffic exchanged among the MCN components, as described in detail herein.
  • the topology data, which is maintained at each Dolfin includes a view of the overlay network for the corresponding tenant. Dolfin is configured to make routing decisions by determining the appropriate aggregator output port from which its traffic is placed on the underlay network, thereby avoiding the requirement for Dolfin to maintain knowledge of the tunneling via the underlay network.
  • Figure 4 is a block diagram of an example multi-cloud configuration including components of the MCN, under an embodiment. While the MCN of this example embodiment includes components distributed among multiple
  • the first cloud environment 401 comprises components of the MCN management plane.
  • the management plane components include but are not limited to tenant-facing WEB-UIs, the WEB-APP, Bouncer, provisioner, one or more load balancers (LBs), components configured for monitoring the health of MCN components and logging data of the monitoring, and one or more data stores or databases supporting the WEB-APP, Bouncer, provisioner, and monitoring/logging components.
  • LBs load balancers
  • the second cloud environment 402 includes an underlay network of a first provider over which MCN components are deployed to form a first overlay network.
  • the MCN components comprising the first overlay network include a set of components deployed per tenant at each POP, and the set of components deployed per tenant include but are not limited to Orcas, Dolfins, Watchdogs, aggregators, and OVSs.
  • the Orcas, Dolfins, and Watchdogs comprise the control plane, and the OVS comprises the data plane, but embodiments are not so limited as described in detail herein.
  • the MCN overlay network components also include monitoring and logging components configured for monitoring the health of MCN components and logging data of the monitoring (e.g., Filebeat) as described in detail herein.
  • the MCN overlay network components are coupled to the management plane components via a load balancer, but are not so limited.
  • the third cloud environment 403 includes an underlay network of a second provider over which MCN components are deployed to form a second overlay network.
  • the MCN components comprising the second overlay network include a set of components deployed per tenant at each POP, and the set of components deployed per tenant include but are not limited to Orcas, Dolfins, Watchdogs, aggregators, and OVSs.
  • the MCN overlay network components also include monitoring and logging components (e.g., Filebeat) as described herein.
  • the MCN overlay network components are coupled to the management plane components via a load balancer, but are not so limited.
  • the MCN comprises multiple POPs coupled via network links and forming an overlay network configured to exchange network configuration data and route data traffic of tenants, as described in detail herein.
  • Figure 5 is a block diagram showing
  • the POP of this example embodiment includes a software-enabled server coupled to support multi -tenant traffic routing of two tenants TEN1/TEN2 and other POPs or components in the MCN and/or WAN.
  • the POP includes two Orcas ORCA1/ORCA2 configured to support each of two tenants TEN1/TEN2, respectively.
  • the first Orca ORCA1 corresponding to the first tenant TEN1 is coupled to a first Dolfin Dolfinl
  • the second Orca ORCA2 corresponding to the second tenant TEN2 is coupled to a second
  • Embodiments are not limited to having an Orca dedicated to a tenant and instead may support multiple tenants using a single Orca.
  • Tenant traffic routing functionality of an embodiment comprises two components Orca and Dolfin in the control layer of the MCN.
  • Orca is configured to transfer or pass tenant traffic from/to the tenant via the tunnel or last mile connection (e.g., public network, VPN, etc.), and from/to the MCN via the corresponding Dolfin.
  • Each of the Dolfins Dolfin l/Dolfm2 includes a container (e.g., Docker container) configured to support each of the respective tenants TEN1/TEN2 but is not so limited.
  • Each Dolfin is configured as a control agent and includes routing control algorithms, and generates the routing table of the POP.
  • Each Dolfin is also coupled to a component configured as a monitoring agent and referred to herein as Watchdog (not shown).
  • Each Dolfin is also coupled to an OVS OVS1/OVS2, and the OVS couples or connects to the underlay network via an aggregator and physical links, as described herein.
  • Embodiments include a rate limiter (output rate limiting) (not shown) dedicated to each tenant and configured to rate limit the data traffic of the corresponding tenant prior to transmission of the traffic over the MCN.
  • the rate limiter is configured to determine the capacity of data handled (e.g., received, sent) by its corresponding tenant.
  • Embodiments can include the rate limiter as a component of the OVS when the OVS is dedicated to a tenant, however alternative embodiments can rate limit the traffic elsewhere in the POP prior to the traffic reaching the OVS.
  • Embodiments include cross-connections between the OVSs of a POP, and the cross-connections are configured so in the event of a failure of an OVS, at least one other OVS of the POP is configured to replace the functionality of the failed OVS.
  • Dolfin While Orca is configured to control entry of traffic into the core network, Dolfin controls traffic routing and flow through the core network such that when each Dolfin receives packets, it controls the routing of those packets via the underlay network to another Dolfin in the core network.
  • the Dolfin of that egress POP sends those packets to the corresponding Orca, which sends them to the egress destination via the Internet.
  • Each POP supports each tenant with a dedicated OVS, and the OVSs of each tenant couple to an aggregator.
  • Each POP includes a hypervisor configured as its master operating system, and the hypervisor of an embodiment comprises the OVS configured to include the aggregator as described in detail herein.
  • the aggregator is configured as an agent communicating with and controlling the POP switching fabric that includes the network interface card (NIC), which is the routing data plane of the overlay network. Consequently, as the connection or bridge between the overlay and underlay networks, the aggregator is configured as a software router managing the connections of the Dolfins to the underlay network via the NIC and POP outputs, and in this manner configures each POP to operate as a router.
  • NIC network interface card
  • the aggregator inputs include the outputs of the OVS instances hosted at the POP, and the aggregator output includes a physical link to the underlay network.
  • the underlay network that links POPs includes multiple single-hop tunnels configured to separate the traffic of multiple tenants of the MCN and, similarly, the aggregator outputs from a POP include numerous ports corresponding to the tenants served by that POP.
  • the routing of an embodiment therefore maintains separation between tenant traffic using single-hop links (e.g., VXLAN) over the tunnel that corresponds to the tenant.
  • Each Dolfin of the POP is configured to provide its data traffic to each
  • each aggregator controls routing of its data traffic to neighboring POPs via the respective link to the neighboring POPs. More particularly, each aggregator receives an input from each Dolfin Dolfin l/Dolfm2 of the host POP, and is coupled to output data traffic to the network links as described in detail herein. Each aggregator is configured to control routing of the data of its corresponding tenant using information of a tenant routing table corresponding to the tenant. The tenant routing table of each tenant is generated by the corresponding Dolfin Dolfml/Dolfm2 and maintained at data plane OVS elements of the corresponding Orca and Dolfin, where it is used as the routing table to control traffic routing, as described in detail herein.
  • Orca is configured to manage incoming connections with the corresponding tenant and security
  • Dolfin is configured to manage routing of traffic
  • the aggregator is configured to control virtualization of output links to the MCN, thereby realizing multi-tenancy at the aggregator layer through the use of aggregator configured to support each outside link of the POP.
  • Each POP includes, for each tenant, a Dolfin configured as a control agent, and a Watchdog configured as a monitoring agent as described in detail herein.
  • Figure 6 is a flow diagram for operations of the Dolfin, under an embodiment. Generally, the
  • Watchdog collects link metrics data for its local links and provides the metrics data in turn to Dolfin, which operates to process the data and generate link state data.
  • Dolfin For clarity, this example shows a single Dolfin of a POP, but embodiments are not so limited as each POP includes a number of Dolfins corresponding to a number of tenants or tenants for which it routes data traffic.
  • the Watchdog is configured to establish a TCP connection to the Dolfin during network provisioning or setup. Following establishment of the connection, the Dolfin receives a registration message from the Watchdog and replies to the Watchdog with a configuration message configured to define a tick rate and a timeout. The Watchdog continues to send the latest measurement data to the Dolfin at the defined rate through the established TCP connection. The Watchdog is configured to continue attempts to reconnect with the Dolfin if the connection is lost.
  • the Dolfin which comprises an input/output (I/O) system or component, includes or is running an event loop.
  • the event loop of an embodiment includes an event loop of the Open Network Operating System (ONOS), but is not so limited.
  • ONOS is a framework configured to receive other software plugins, and an embodiment includes as a plugin a routing engine program or algorithm that controls real-time data routing through the MCN.
  • the real time distributed autonomous feedback control system for data routing of an embodiment is referred to herein as Hop-by-hop Adaptive Link-state Optimal (HALO), and includes multiple routing behaviors as described in detail herein.
  • HALO Hop-by-hop Adaptive Link-state Optimal
  • An input of the Dolfin includes monitoring information, including per-link metrics.
  • the monitoring information is input to the Dolfin from the Watchdog, which is configured to collect and/or generate this information as described in detail herein.
  • the input of an embodiment is provided to the Dolfin (from the Watchdog) at a rate (Delta t- monitoring) of approximately every 10 milliseconds (ms), but is not so limited.
  • the Dolfin receives and writes (“fires”) the input information into a single server at a rate (Delta t-control) of approximately 250 ms, but is not so limited as alternatives receive and write the input information at a rate of up to approximately 100 milliseconds.
  • the durations described herein are exemplars only, and both Delta t-monitoring and Delta t- control values are tunable and can be changed as appropriate to a system configuration.
  • An output of Dolfin includes flow table entries.
  • the routing engine Upon receipt by the Dolfin of the link metrics data and, additionally receipt of link state information from other Dolfins in the MCN, the routing engine is configured to determine“best paths” for routing data based on policy or objective functions, as described in detail herein.
  • Embodiments define the“best” path in terms of“distance” using available link state data and an objective function that corresponds to a traffic class of the data. Different link state data can be applied to different objective function types, resulting in numerous different definitions of distance, or“best path”. For example, application of loss rate data to a corresponding objective function results in a best path that is a loss“distance”, and application of latency data to a corresponding objective function results in a different best path that is a latency“distance”.
  • distance is defined using a combination of link metrics, in which case one or more weightings is applied to the link metrics.
  • the routing engine determines or generates a route for tenant data, and the route is generated based on a routing policy or performance objectives corresponding to that tenant.
  • the routing engine then pushes the generated route, comprising flow table entries, to the corresponding OVS.
  • the OVS generates a routing table using the flow table entries, and uses the routing table to control routing of data over the corresponding POP link. Real-time rerouting of data involves generating and inserting or publishing new flow table entries corresponding to a new route.
  • the Dolfin can generate and push out/insert/publish routing data for multiple POPs, or routing data can be generated in one or more other components of the MCN.
  • Components of the MCN are configured to generate end-to-end route statistics or metrics and provide the metrics to the control plane.
  • the POPs consider and therefore gather data (e.g., real-time, static, pre-specified intervals or periods, etc.) relating to numerous metrics when determining the state of network.
  • each Watchdog is configured to probe or gather the monitoring data for links to which it is coupled or connected, but embodiments are not so limited.
  • the POPs measure loss rate of each link at a pre-specified rate, and maintain an average or moving average of the measured loss rate over a period of time.
  • the POPs also measure latency of each link in the network and, using the latency data, determine or calculate a latency variation, also referred to as jitter.
  • jitter a latency variation
  • embodiments measure or determine available bandwidth between points in the network.
  • Link state data are collected or determined on a per-tenant basis, but are not so limited and could be collected per link regardless of tenant.
  • FIG. 7 is a flow diagram for operations of the Watchdog, under an
  • this example shows a single Watchdog of a POP, but embodiments are not so limited as each POP can include multiple Watchdogs
  • an embodiment can include a Watchdog corresponding to each tenant, an alternative embodiment can include a single Watchdog configured to support multiple tenants.
  • the output of the Watchdog includes link metrics (per link) related to corresponding link(s) and utilization, and is output to the corresponding Dolfm(s) and to central monitoring as described in detail herein.
  • the central monitoring infrastructure of an embodiment is implemented using the ELK stack, also referred to as Elasticsearch, Logstash, and Kibana (ELK) stack, as described in detail herein, but is not so limited.
  • the Watchdog of an embodiment is plugged into or coupled to the aggregator, and configured to perform heartbeat monitoring across the overlay network assets.
  • the heartbeat monitoring comprises sending or transmitting a heartbeat signal or packet at a pre-specified rate (Delta-t) across all connected links.
  • the pre-specified rate at which the heartbeat signal of an embodiment is sent is approximately 10 ms, for example, but this rate is tunable and can be changed to alternative rate(s) as appropriate to a system configuration.
  • the heartbeat packet is sent across a single hop and, in response, data regarding or representing latency of the link is collected and/or returned from the packet recipient.
  • heartbeat signal of an embodiment is a single-hop signal
  • embodiments are not so limited and can include multiple hop packets that traverse and/or collect or result in return of data across multiple hops or links.
  • the Watchdogs throughout the MCN overlay are continuously sending and receiving packets
  • the Watchdog performs processing operations on the collected or received data.
  • the processing includes data averaging (e.g., moving average, etc.) or smoothing routines, but is not so limited.
  • One or more components of the processed data are provided to the Dolfin as described in detail herein.
  • the Watchdog is configured to push data to the Dolfin.
  • the Watchdog is configured as an event-driven system that pushes data according to an event-response model. For example, latency data is pushed to the Dolfin by the Watchdog when the latency is determined by the Watchdog to exceed a pre-specified or pre-defmed latency threshold or “event”.
  • the control plane uses the link state data of each Watchdog to determine algorithmically the link metrics for the entire network.
  • embodiments are configured to monitor probe metrics continuously at a certain rate.
  • the Watchdog includes parameters that define the tick rate and timeouts.
  • the Watchdog sends data to the Dolfin at a specified tick rate, which is controlled by the Dolfin.
  • the Dolfin is configured to change or update the tick rate by sending a configuration message to the Watchdog through the TCP connection.
  • the Watchdog is configured for relatively high-speed probing.
  • An embodiment includes a dedicated processor running the Watchdog and controlling probing operations of MCN components. This probing container is separated from routing control and forwarding functions, both of which are performed by the Dolfin running under another dedicated container configured to control data routing and forwarding.
  • the Watchdog collects latency data using the heartbeat signals, and that information is in turn output to the Dolfin, which operates to process the data and generate link metrics data. In the event of failure of the Watchdog, the Dolfin continues routing operations using data previously received from the Watchdog.
  • Embodiments include a provisioner configured to manage configurations of the MCN components along with configuration of other network resources, as described in detail herein.
  • the provisioner is configured to control network provisioning involving the underlying infrastructures of the underlay network providers, and to control network configuration involving deploying MCN components to operate over the underlying network according to configuration parameters of the corresponding tenant.
  • the provisioning of the underlay and overlay networks includes use of network configuration information provided by the tenants but is not so limited.
  • the MCN configuration of an embodiment provisions and configures the overlay network to operate independently of any underlying network or network assets.
  • the MCN configuration when operating in a public cloud infrastructure, does have some reliance on underlying networks of the public infrastructure for routing data.
  • An issue that can arise is that initiating operations of and provisioning the network of an embodiment operating or running in a public cloud infrastructure can take significantly more time than when operating exclusively on dedicated private servers. This additional provisioning time is a result of the reliance on the public cloud infrastructure provider to provision and/or start up the infrastructure assets (e.g., APIs, VMs, rule setup on the backbone, etc.) in order to provide the underlying connectivity used by the overlay network.
  • the provisioner of an embodiment includes or couples to a pre-provisioned queue of networks.
  • embodiments Using this pre-provisioned queue, and in response to a user request for a network, embodiments initiate operations of the overlay network with a pre-provisioned network identified from the pre-provisioned queue. In this manner, embodiments minimize or eliminate any additional provisioning delay required as a result of use of public cloud assets.
  • the overlay network system includes a web application (WEB-APP) configured to include a tenant-facing web or web-based user interface (WEB-UI). While the provisioner initializes or configures components of the MCN as described herein, it is generally configured to provision the assets of the overlay network using information provided by an authorized user via the UI.
  • WEB-UI which is generated by the web application and presented to a user, is configured to receive login credentials of an authorized tenant or user. At the first instance of tenant login, the WEB-UI prompts the user to name the network, and to input or specify network configuration information.
  • the network is configured to use the configuration information or data, as described in detail herein.
  • the MCN further includes a Bouncer that is configured to validate a user based on the login credentials by checking or determining permissions of an authorized user, and determining that the user belongs to an tenant group with authorization to access the overlay network.
  • a Bouncer of the MCN is configured to register users, perform authorization of users, and manage security and access to the MCN.
  • the Bouncer is also configured to manage users, organizations, roles, permissions, and resources.
  • the Bouncer is configured to authenticate communications between the WEB-APP and other service users (e.g., Dolfin, Orca, etc.) of the MCN.
  • MCN components interact to provide a global autonomous private core network including global control and optimization of data traffic through or in networks including software- defined networks.
  • the system includes a web user interface (UI) (WEB-UI) that is configured as a web portal by which tenants configure and monitor their networks.
  • UI web user interface
  • WEB-UI web user interface
  • a user logs in through their web portal to manage the network(s) of their organization and users, and navigates to the URL of the web portal.
  • the system is configured to fetch an index file (e.g., from S3), and the web-UI is rendered from the index file.
  • the WEB-UI interacts with a web application (WEB-APP), and with a load balancer, such that API calls and data rendered for the WEB-UI is exchanged between the WEB-UI and the WEB-APP.
  • WEB-UI which in an embodiment is written in JavaScript using the Ember js framework, includes one or more plug-in components configured to render the pages of the WEB-UI, but is not so limited.
  • the WEB-UI is served to the user from the content delivery network (CDN).
  • CDN content delivery network
  • the WEB-APP serves the base page to the WEB-UI upon login, and the base page crosslinks to the CDN assets.
  • the WEB-UI makes REST calls to the WEB-APP via a live websocket coupling to the WEB-APP, and maintains the connection for pushing metrics.
  • the various pages of the WEB-UI are subsequently displayed via REST queries to the WEB-APP, which displays the corresponding pages as appropriate.
  • the WEB-UI is configured for use in accessing live network metrics, historical network metrics, editing network topology (e.g., drag-and-drop), and providing alerts and notifications.
  • the WEB-UI is also configured for use in managing tenant network assets including but not limited to organizations, users, networks, routes, alerts, notifications, traffic classes, and roles.
  • the WEB-UI is further configured for use in accessing or working in the sandbox environment, and accessing an optimization tool configured to compute solutions comprising inputs including a demand matrix and topology matrix, and outputs including routing recommendation or distribution weights.
  • This information is accessed via the WEB-APP, which is configured as an application gateway, API gateway, and authorization gateway configured to manage authentication and
  • Embodiments include one or more of graphs, maps, and dashboards configured for presentation of network data via the WEB-APP.
  • Live network metrics which are accessed via a web socket connection, comprise network metrics such as packet loss, jitter, latency, throughput (per link, per traffic class), utilization, connection metrics, and link status.
  • the metrics including jitter, latency, and throughput are provided from Watchdog through Dolfin, and the connection metrics, or metrics related to users connected to the MCN (e.g., number of connected users, number of live sessions), are provided by Orca, as described in detail herein.
  • Historical metrics include aggregate data metrics/usage over a period of time (e.g., minute, hour, day).
  • the WEB-APP is further configured as the ingest for control plane metrics and, as such, saves the control plane metrics to the data store, and pushes the metrics out to the live connections at a pre specified interval (e.g., push-based per second, etc.).
  • the WEB-UI is configured to enable a user to manage organizations, users, networks, routes, traffic classes, alerts, notifications, and roles.
  • the WEB-UI is configured for use in creating, updating, and listing organizations. Within a list of organizations, the user can sort organizations, get organizations, and mark organizations as favorites.
  • the WEB-UI is configured to manage users, including listing, creating, updating, deleting, assigning and listing roles, sending emails (invite, password reset), sorting (on role), filtering, and searching.
  • the WEB-UI is configured to enable a user to manage networks, including provisioning or creating a new network, and listing networks. During the provisioning of a network, a user specifies network parameters like name and bandwidth via the WEB- UI. Network management via the WEB-UI also includes updating network capacity, and controlling dynamic capacity assignment as described herein. Network management via the WEB-UI includes enabling a user to access a network diagram or topology editor.
  • the network topology editor includes a drag-and-drop interface by which a user can edit both operational and simulated networks.
  • the editing functionality enables users to create nodes, name nodes, connect links between nodes, move nodes, delete nodes, and specify link capacity.
  • the WEB-UI is further configured to enable a user to manage routes, including listing, creating, deleting, and updating routes.
  • Route management also includes but is not limited to enabling a user to specify route type (virtual private network (VPN) (secure sockets layer (SSL), Internet Protocol security (IPsec)), and cloud-based applications (Salesforce, Office 365, Workday), etc.).
  • VPN virtual private network
  • SSL secure sockets layer
  • IPsec Internet Protocol security
  • cloud-based applications Sasforce, Office 365, Workday
  • the WEB-UI is configured to enable a user to manage traffic classes, which is a feature of the core routers (Dolfin).
  • the management of traffic classes via the WEB-UI includes creating, modifying, listing, and deleting traffic classes.
  • Embodiments also report traffic-related metrics by traffic class, as described in detail herein.
  • the WEB-UI is configured to enable a user to manage alerts through REST APIs with the WEB-APP.
  • the management of alerts includes creating, modifying, updating, listing, and deleting.
  • the WEB-UI is configured to enable a user to manage notifications, including creating notification in the WEB-APP, and listing notifications in the WEB-UI.
  • the WEB-UI is configured to enable users to access and work in a sandbox environment of the MCN as described in detail herein.
  • the sandbox which is created using the network editor, is configured to enable users to run simulated networks, run simulated traffic (including providing live network metrics), run speed tests (on selected source/destination pair) and dynamically push throughput, and compare other network types with MCN.
  • the sandbox of an embodiment uses the Mininet network emulator, but is not so limited.
  • the WEB-UI includes a high availability view for access and use by site administrators.
  • the high availability view includes a display of each VM, stack (Orca, Dolfin,
  • Watchdog, etc. This is in contrast to other views that consolidate the assets of each physical location into a single-asset view. In this manner, the high availability view provides a relatively finer-grained view for use in debugging, for example.
  • the WEB-UI is configured to enable users to access a matrix computation calculator.
  • This calculator is configured to receive inputs comprising an adjacency matrix and demand matrix, and in turn to generate distribution weights.
  • the WEB-UI includes a disruptor UI configured for access by network administrators.
  • the disruptor UI functions as the interface for a disruptor that is a submodule of the provisioner.
  • the disruptor UI is configured to enable users to enable/disable HALO, bring links up/down, add latency and packet loss, inject traffic, turn on/off containers/components (Dolfin, Orca, Watchdog), and restart a POP.
  • the MCN is configured to include a web-based login service by which a tenant or user logs into the MCN to manage the network(s) of their organization and users, and navigates to the URL of the web.
  • Figure 8 is a flow diagram for log in and
  • This service is HTTPS-based (e.g., HTTP and TLS) but is not so limited.
  • Each POP includes and runs multiple copies of the login service, referred to as a service-pool, with a front-end load- balancer so as to provide high availability and fault tolerance in the event of a single POP being unavailable.
  • This service-pool is multi -tenant, in that it is backed by a read-replica relational database management system (RDBMS) database instance comprising the end- user credentials for all the end-users of all the tenants.
  • RDBMS read-replica relational database management system
  • the login service is configured for use by a tenant in provisioning end-user credentials so that the login service can authenticate against a list of pre-approved end- users.
  • the read-replica is configured to synchronize credentials with the main Bouncer database.
  • the tenant administrator is enabled to set up end-user logins in the main Bouncer database and, once these logins are created, they are synchronized via a secure connection (e.g., TLS) to all the read-replicas in all POPs of the MCN.
  • TLS secure connection
  • the service When an end-user successfully authenticates with the login service, the service installs rules (e.g., Openflow) in the Orca of the ingress POP corresponding to the tenant. These rules only allow traffic from the source IP address detected by HTTP service.
  • rules e.g., Openflow
  • the login service is accessible behind a well-defined, and pre-established domain name (e.g., https://login.modecore.net/), which is geographically load balanced using DNS to send the end-user to the nearest geographic instance of the service-pool as described in detail herein.
  • the login service is distributed in order to allow the user to authenticate her use of the MCN via the nearest geographic POP. In the event that a POP is unavailable, the health check for the POP will fail, and the DNS routing layer will redirect the user’s login request, and subsequent VPN traffic to another POP.
  • the service includes knowledge of the source IP address distribution of all incoming VPN connections. This information, along with enabling a source IP address firewall, reduces the attack surface of DDoS attacks on a tenant data-plane.
  • the WEB-UI interacts with a WEB-APP of the management plane, as described herein.
  • the WEB-APP includes an application server configured to serve and manage connections to the WEB-UI, and to control login, registration, and password recovery processes. Additionally, the WEB-APP is configured as an application gateway, API gateway, and authorization gateway to manage authentication and authorization between the WEB-UI and components that receive information input via the WEB-UI.
  • the WEB-APP is an intermediary between the WEB-UI and the Bouncer for information regarding core network access.
  • the WEB-APP is the intermediary between the WEB-UI and the provisioner for provisioning requests and related information input via the WEB-UI. The Bouncer and provisioner and their corresponding interactions are described in detail herein.
  • the WEB-APP is configured to be the intermediary between the WEB-UI and other components of the MCN.
  • the WEB-APP is an intermediary in the process for onboarding a new client.
  • Figure 9 is a flow diagram showing components and information flow for onboarding a new client, under an embodiment.
  • the WEB-APP is an intermediary in the process for creating and inviting other uses in an enterprise (tenant).
  • Figure 10 is a flow diagram showing components and information flow for creating and inviting other uses in an enterprise, under an embodiment.
  • the WEB-APP is also configured as a metrics service that receives and pushes network metrics to the WEB-UI.
  • the WEB-APP receives and collects network metrics data reported by the Dolfins and Orcas of the MCN, and indexes the collected data in a corresponding database (e.g., Couchbase).
  • the WEB-APP manages connections to the WEB-UI (e.g., Redis) and pushes the metrics to the WEB-UI, which is configured to present the metrics to an authorized user via a dashboard, for example.
  • the WEB-APP is collecting network metrics data, it includes and manages an alerts engine that manages alerts (e.g., create, update, delete, etc.) and corresponding notifications.
  • the alerts and notifications correspond to the link metrics as described herein.
  • the alerts engine upon receipt of an alert, determines if there is a corresponding notification and, if so, generates the notification and provides it to the WEB-UI.
  • Bouncer Another component of the management plane, or middleware, is Bouncer, which encapsulates and centralizes the features of the MCN around authentication and authorization.
  • the Bouncer In its role managing security and access to the MCN, the Bouncer provides an API (e.g., private facing, REST) to other MCN components accessing the service.
  • REST private facing, REST
  • this role Bouncer performs all authorization, and stores a collection of all resource types and identification so that it can determine if users are authorized to execute operations involving the resources.
  • Bouncer encapsulates its data store for managing users, organizations, roles, permissions, and resources, and supports multi-tenancy with use of a relational database that includes tables for organizations, and for binding users to organizations, and roles to users. Bouncer is configured for use in creating organizations and, additionally, updating and listing organizations. Within an organization list the user can sort organizations, get organizations, and mark organizations as favorites.
  • Bouncer is configured to register users and perform authorization of users. Further, Bouncer manages users, including managing creation, removal, and update of users and their related information, including creating new users, removing users, updating details of a user, returning a list of all users, returning detailed information about users, returning the roles associated with a user, adding a new role to a specified user, and removing a role from a user. Bouncer is further configured to use tokens for sessions with authenticated users, but is not so limited.
  • Figure 11 is a flow diagram for an authentication of Bouncer including use of tokens, under an embodiment.
  • a user Prior to any action, a user first requests a token from Bouncer.
  • Bouncer validates the user credentials, stores a token with some “session” information, and returns the token to the user. This token is used for any subsequent calls to the system.
  • the token of an embodiment includes identification data, and can include one or more of user id, organization ⁇ (tenant id), roles, permissions, expiration time, and audit id, for example.
  • Bouncer In addition to authenticating users, Bouncer also authenticates communications between the WEB-APP and other service users (e.g., Dolfin, Orca, etc.) of the MCN. In so doing, tokens are used between the WEB-APP and each service user needing to provide data to the WEB-ET via the WEB-APP. Embodiments cache these tokens at the WEB-APP in order to avoid overloading the WEB-APP with authentication requests. Provisioner
  • Embodiments include a provisioner configured as the orchestration system of the MCN to manage configurations of the MCN components along with configuration of other network resources (e.g., underlay network components).
  • the provisioner is configured to control network provisioning and network configuration.
  • the network provisioning operations involve the underlying infrastructures of the underlay network providers, while the network configuration operations involve deploying MCN components to operate over the underlying network according to configuration parameters of the corresponding tenant.
  • the provisioner controls the interplay between the management plane and the control plane to create or provision underlay networks.
  • the provisioner also provisions or configures networks over (“overlay networks”) the underlay networks by deploying (through APIs) components of the MCN (e.g., Dolfins, Orcas, Watchdogs) in the overlay network.
  • the provisioner is further configured to create routes for existing networks, and to store data representing the underlay networks, overlay networks, and route configurations. Dolfins and Orcas communicate with the provisioner to receive information representing network configuration, routes, and traffic classes.
  • the provisioner code of an embodiment is written in Python, and Ansible is used to run tables, but embodiments are not so limited.
  • Figure 12 is a flow diagram for network provisioning, under an embodiment.
  • the provisioning of underlay networks generally comprises interactions between the provisioner and one or more APIs in order to create networks.
  • the provisioner identifies the cloud type and the topology, and controls network preparation in accordance with the identified type and topology.
  • the provisioner uses the identified network for deployment of the components. If no such network is available, the provisioner uses its cloud-type specific API to request creation of a network.
  • the provisioner deploys the MCN components (e.g., bridges, containers, etc.) over the network.
  • the network information or data is consolidated and stored in a network table.
  • the provisioner of an embodiment is configured to manage the network provisioning requests (e.g., creation, modification, deletion, etc.) of each tenant by provisioning (e.g., creating, modifying, deconstructing, etc.) networks in one or more cloud networks (e.g., Azure, Ericsson, etc.). Further, the provisioner is configured to deploy MCN components (e.g., OVS, Dolfin, etc.) in the provisioned network, test the provisioned network, and/or notify a tenant of the provisioning result (failure/success).
  • MCN components e.g., OVS, Dolfin, etc.
  • the provisioning of a network is initiated with a provisioning request API request) that is generated by a user at the WEB-UI, and provided to the provisioner via the WEB-APP.
  • the provisioner analyzes the request to determine data of the cloud type requested for the network, network topology (e.g., number of locations, etc.), network capacity, and high availability factor (specifies if created network is to have the high-availability configuration).
  • the provisioner next accesses its database (e.g., PostgreSQL), which includes data of the underlay and overlay networks, to determine if a provisioned underlay network is available.
  • PostgreSQL PostgreSQL
  • the provisioner determines the remaining link capacity of this underlay network, and determines a number of overlay networks currently running over the underlay network. If the existing underlay network has adequate capacity to host a new overlay network, then the provisioner creates the new overlay network over the existing underlay network, adds the new overlay to the database, and provisions the MCN components (e.g., Dolfins, Orcas, Watchdogs) in the new overlay network. In contrast, if the existing underlay does not have adequate capacity, then the provisioner creates or provisions a new underlay network via an API of the underlay network provider API.
  • MCN components e.g., Dolfins, Orcas, Watchdogs
  • the provisioner is configured to provide private APIs (e.g., REST API) to the tenants, but is not so limited.
  • the provisioner which in an embodiment is a component of the middleware or management plane, also includes and/or is coupled to a data store at which it maintains data of provisioned networks, but is not so limited. More particularly, the MCN is configured to store at the provisioner multiple topologies for each tenant, along with a provisioning status file, a topology file, VPN profiles (routes in general), SD-WAN profile data (e.g., IPs/locations of CPE devices, access information for SD- WAN master director, etc.), error files for each topology, and an overall time recording file, to name a few. Because the provisioner maintains access to the clouds where networks can be provisioned, it also maintains corresponding cloud authentication information.
  • the provisioner is configured with a portal configured to access (with use of appropriate access credentials) and establish communication with an SD-WAN portal of an SD-WAN provider.
  • the provisioner is configured to provide information to the SD-WAN provider (e.g., identity of the MCN POP closest (geo-location) to the SD- WAN portal, method to contact the closest POP, etc.) via a template, and install the template at the SD-WAN CPE.
  • the template is committed, which applies the MCN settings at the SD-WAN CPEs, thereby configuring the SD-WAN to communicate with the MCN via the closest POP.
  • FIG. 13 is a flow diagram of a provisioning example, under an embodiment.
  • the provisioner communicates with components of the middleware (not shown) via the API tools.
  • This example shows the provisioner receiving via an API a provisioning request including a network description, provisioning networks in two different cloud networks 1301/1302 in response to the request, and returning via the API information representing a result of the provisioning, but embodiments are not so limited.
  • the provisioning requests are generated by a user, or network administrator of the
  • Embodiments include a load balancer and/or a queueing system for use in handling multiple provisioning requests, but are not so limited.
  • the provisioning request includes information about the network topology, type of cloud, tenant identification (ID), and network topology ID.
  • The“provision network” request of an embodiment arrives in a form of a request (e.g., HTTP POST), and the body of each request includes a file (e.g., JSON) comprising the information necessary to provision the network (e.g., network topology id, tenant id, cloud type, etc.), but embodiments are not so limited.
  • the provisioner first checks its data store to determine if the provided network topology ID of the provided tenant ID already exists. This involves the API determining if a pre-provisioned network is available for immediate dedication to the requesting tenant. If there is an available pre-provisioned network, the API returns a message and/or code so indicating (e.g.,“provisioned network available” with status code 200).
  • the API starts a network provisioning process by checking if the network topology requested by the tenant has already been provisioned in response to a previous request, or was in error.
  • This checking of network topology in an embodiment comprises checking for the existence of both the status file and the topology file as well as the content of the status file, but is not so limited. If only one of the two files exist, then it is categorized as an error, and the corresponding data is moved to a specific“error” folder and the provisioning is re- accomplished. If both files exist, and the status file indicates“SUCCESS” or“IN
  • PROGRESS then an error is returned, and the re-provisioning request is rejected. If both files exist, and the status file indicates“ERROR”, then the current data is moved to an“error” folder and the provisioning is re-accomplished.
  • the provisioner determines the requested topology has never been provisioned, and provisioning is initiated in response to the request.
  • the provisioner generates a configuration file specific to the requested topology, including all variables used by the command line interface (CLI) command script of the requested cloud type.
  • the provisioner executes the CLI commands for provisioning a network in the cloud specified by the request.
  • CLI command line interface
  • the provisioner configures MCN components over the underlay networks.
  • Network configuration operations of the provisioner involve configuring MCN components by manipulating database models and creating, updating, and/or removing entries in those models and/or corresponding data tables in accordance with the user-specified configuration data.
  • This user-specified configuration data includes traffic class and route configuration data, but is not so limited.
  • the traffic class configuration data identifies traffic classes, and configures MCN behavior corresponding to each traffic class.
  • the route configuration data includes data of the service the tenant traffic will access.
  • Configuration of the MCN components comprises the provisioner executing provisioning scripts, for example, for deploying MCN components in the provisioned network.
  • the provisioner also executes test scripts to check that all necessary MCN components were successfully deployed, and that basic packet forwarding can be performed.
  • the provisioner responds to the middleware with the provisioning status upon receiving the“status” GET request.
  • the status returned includes but is not limited to“in progress”,“failure” with a corresponding code or description, and success with a corresponding code or description, but is not so limited.
  • the provisioner maintains information of its underlay and overlay networks, and provides the information in response to a request.
  • the WEB-UI is configured for use by a tenant to generate a request for information of networks corresponding to the tenant’s organization, and the WEB-ET sends the request to the provisioner via the WEB-APP.
  • the provisioner in turn responds by providing the requested network information via the WEB-APP, and the information is presented to the user via the WEB-UI.
  • Routes are created to attract tenant traffic, and the provisioner is configured to create the routes.
  • the provisioner is configured to change routes, delete routes, and store route information in its database for retrieval and use by other core network components.
  • the WEB-UI is configured to include a page for route creation, and a user navigates to this page to create routes.
  • a user inputs a URL for a service application (e.g., Salesforce, SaaS, etc.) with which their organization has an account or exchanges data.
  • the provisioner in turn creates a service application (e.g., Salesforce, SaaS, etc.) with which their organization has an account or exchanges data.
  • the provisioner in turn creates a service application (e.g., Salesforce, SaaS, etc.) with which their organization has an account or exchanges data.
  • the provisioner in turn creates a service application (e.g., Salesforce, SaaS, etc.) with which their organization has an account or exchanges data.
  • the provisioner in turn creates
  • FIG. 14 is a flow diagram for configuring a network including setting up a route, under an embodiment.
  • the tenant of an embodiment sends a request to“host.abc.com” and the DNS server for the tenant is configured to change it to“clientl-abc.mode.com” since the DNS server will have a CNAME record changed to“clientl-abc.mode.com” for “host.abc.com.”
  • the DNS service at which the MCN is registered assists in redirecting the traffic to the correct ingress POP (based on the location).
  • the ingress POP corresponding to the tenant receives the traffic, it is configured to route the traffic to the egress POP corresponding to the public IP address for the egress destination service via the best possible path within the MCN.
  • the egress POP then forwards the traffic along with the original tenant information to the egress destination service.
  • the ingress POP of an embodiment is the closest POP to the user, as described in detail herein.
  • a cloud network traffic manager is used to determine the closest POP of an embodiment to serve as the ingress POP, but embodiments are not so limited. In so doing, the cloud network traffic manager determines the location (geographical) at which the request originated, and maps the traffic to a specific IP address of the POP nearest that location. Traffic from the user is subsequently routed to the ingress POP using the mapped IP address of the POP.
  • a scenario can arise where the traffic source is located in the same geographical region as the egress destination. Under this scenario, traffic may be more efficiently routed outside of the MCN. To optimize routing in this scenario, embodiments are configured to directly route the traffic to the egress destination server instead of routing it to the ingress POP.
  • Each component is deployed in a container (e.g., Docker container), and has a corresponding version number.
  • the provisioner includes APIs configured to track version numbers of the components, and to deploy a specific version number of each component on a specific network.
  • the provisioner communicates with WEB-APP, Dolfins, and Orcas.
  • the WEB- APP communicates with the provisioner to obtain information about existing network resources.
  • Dolfins and Orcas obtain from the provisioner information of network configuration, routes, and traffic classes for use in their operations. In so doing, for example, Orcas send a request for route information to the provisioner at some pre- specified frequency or interval and, in response, the provisioner reads the information from the database and returns the route information to the requesting Orca.
  • Figure 16 is a flow diagram for removing network configuration data and removing routes, under an embodiment, under an embodiment.
  • Figure 17 is a flow diagram for releasing an existing network, under an embodiment.
  • the MCN management plane components are implemented in multiple environments, including but not limited to staging, production, beta, quality assurance, and demonstration.
  • Each environment includes two provisioner containers in separate VMs (in AWS), where two provisioner containers provide high availability.
  • a load balancer operates to balance the load between the provisioner containers.
  • the provisioner also includes a database container in a separate database, and the two provisioner containers communicate with the database container.
  • Data representing provisioned underlay and overlay networks as well as route data is stored in the provisioner database and, additionally, uploaded to remote cloud storage.
  • Figure 18 is a block diagram of the provisioner database structure comprising numerous tables, under an embodiment. Orca
  • Each POP includes a set of Dolfins and Orcas corresponding to each of one or more tenants.
  • Figure 19 is a block diagram of a POP, under an embodiment. While only a single Orca and Dolfin are shown in this example, each POP includes a number of Orca/Dolfm pairs that corresponds to the number of tenants served by the POP as described in detail herein.
  • Each Orca which includes a corresponding container, is configured as a gateway router that controls entry of data into the network.
  • Each Dolfin which also includes a corresponding container, is configured as a core router that controls routing of data through the MCN.
  • Each Orca/Dolfm pair is provisioned per tenant in their respective containers.
  • Each of the Orca and Dolfin components is monitoring and controlling an OVS bridge, which is a corresponding instance of a virtual switch in the operating system, and a coupling or connection links the two OVS bridges.
  • the Orca, Dolfin, and corresponding OVSs function together to form the overlay network as described herein.
  • Orca is configured as the gateway of an embodiment to serve as a bridge between the public network (e.g., Internet, WAN) and MCN.
  • Orca which is scalable to support large numbers of traffic flows, is configured to receive or accept traffic flows from the tenant via the ingress attractor (“ingress”), and to transmit traffic flows to the tenant via the public network (“egress”).
  • Orca is configured with VMs to decouple network functions (e.g., network address translation (NAT), firewalls, domain name service (DNS), caching, etc.) from gateway components so they can run in software.
  • Orca is further configured to perform NAT, when attracting traffic of the core network tenants, in order to control routing of packets between the MCN and the first and last mile couplings or connections.
  • Orca secures the core network by allowing only legitimate traffic flows to the MCN and, additionally, forwards legitimate packets between the public network and the MCN while reducing or eliminating additional latency and/or performance penalty.
  • Orca controls the OVS (Orca OVS, or 00 VS) that is coupled or connected to the Internet, and this is the entry/exit point for data traffic to/from the core network.
  • Orca functions as a gateway or bridge between the public Internet or wide area network (WAN) and the MCN.
  • WAN wide area network
  • Orca is configured as a‘firewall’ and only allows traffic into the core network that is addressed to or otherwise configured for the core network and originating from an expected address of a tenant, and in this manner limits access to the core network to only authorized tenants.
  • packets received at a POP from an IP address not recognized as a MCN tenant address are dropped.
  • the OOVS also connects to the host name space, which is a test component used to inject data into the core network that is generated for testing and debugging operations, for example.
  • the Dolfin OVS includes a first port connected to the gateway router via the OOVS.
  • DOVS also includes an output port that connects to the underlay network via an aggregator OVS (“aggregator”) and physical links as described herein.
  • DOVS also includes a rate limiter (output rate limiting) configured to rate limit outgoing traffic of the corresponding tenant.
  • Orca is configured to control ingress/egress of traffic into/from the core network
  • Dolfin controls traffic routing and flow through the core network such that when each Dolfin receives data traffic, it controls the routing of the traffic via the underlay network to another Dolfin in the core network.
  • the Dolfin of that egress POP sends the traffic to the corresponding Orca, which sends it to the egress destination via the last mile coupling or connection (e.g., Internet).
  • An embodiment includes multiple overlay networks on a single underlay network, so that a set of POPs, and their hosted VMs, distributed among various geographical locations supports multiple isolated overlay networks.
  • Each of the multiple overlay networks has a configuration that is independent of any other overlay network and is controlled according to the configurations of its one or more corresponding tenants.
  • multi-tenancy is realized in embodiments through the use of multiple Orca and Dolfin containers in a POP, each of which is provisioned per tenant, and additionally through use of the aggregator as described herein.
  • Each POP supports multiple tenants and, as such, the output of each DO VS corresponding to each tenant connects to an aggregator.
  • the aggregator comprises an OVS, referred to as the aggregator OVS (AO VS). More particularly, an embodiment includes a single instance of OVS running in hypervisor, and this instance of the OVS comprises the AOVS as well as the OOVS and the DOVS (logical separation).
  • the aggregator is configured as the connection or bridge between the overlay and underlay networks.
  • Figure 20 is a block diagram of an aggregator, under an embodiment.
  • the aggregator inputs include the outputs of the DOVSs instances hosted at the POP, and the aggregator output includes a physical link to the underlay network.
  • the underlay network that links POPs includes multiple single-hop tunnels configured to separate the traffic of multiple tenants of the MCN and, similarly, the aggregator outputs from a POP include numerous tunnels corresponding to the tenants served by that POP.
  • embodiments include a tunnel corresponding to each tenant of the MCN. Outgoing data traffic of each tenant is tagged with a tag that corresponds to the originating tenant. The traffic is then routed to the destination POP according to the tag.
  • the routing of an embodiment therefore maintains separation between tenant traffic using single-hop links over the tunnel that corresponds to the tenant.
  • the data Upon arrival at the aggregator of the destination POP, the data is routed by the aggregator to the Dolfin that corresponds to the tenant associated with the tag.
  • Figure 21 is a block diagram of example aggregator couplings or connections, under an embodiment.
  • the aggregator comprises multiple aggregator bridges, and each aggregator bridge is connected to a corresponding Dolfm/DOVS pair of the host POP.
  • Each aggregator bridge further includes a set of ports that connect via the underlay link to a set of MCN POPs.
  • Each port of each aggregator bridge connects to a different POP of the MCN, such that the aggregator bridges of each aggregator collectively link to all other POPs in the MCN. Consequently, traffic addressed to a specific destination POP in the MCN is sent to that POP by the aggregator bridge/port corresponding to that destination POP.
  • the links between the aggregators of the MCN servers comprise tunnels (e.g., VXLAN, Generic Routing Encapsulation (GRE), etc.) in the underlay network, and the tunnels each correspond to a separate tenant of the MCN as described in detail herein.
  • tunnels e.g., VXLAN, Generic Routing Encapsulation (GRE), etc.
  • GRE Generic Routing Encapsulation
  • a traffic flow enters the MCN from a tenant via the gateway router or bridge (Orca), which routes the traffic to a tenant bridge that includes the Dolfin corresponding to the tenant. Based on the destination address of the incoming traffic, the Dolfin routes the traffic via its DO VS to the aggregator bridge having the port corresponding to the destination address. The aggregator bridge then transmits the traffic to the appropriate destination POP via a corresponding tenant tunnel in the underlay. Therefore, for example, data traffic from Tenantl addressed to a tenant served by the Dallas POP is routed to aggregator bridgel via gatewayl and OVS1, and aggregator bridgel outputs the traffic on its port corresponding to the Dallas POP.
  • Data from a tenant is received at an ingress POP, and the MCN routes that incoming data to an egress POP from which it is transmitted to the egress destination. More specifically, the Orca at the ingress POP receives traffic from the tenant, and the Orca at the egress POP outputs the traffic to the egress destination.
  • configuration involves a tenant creating a network, including specifying configuration information relating to intended use of the network.
  • the tenant intends for its users to access one or more particular remote services (e.g., SaaS, SalesForce, etc.) via the network, so the tenant provides or inputs configuration information representing or relating to the remote service (egress destination) (e.g., domain name, IP address, etc.) in order to configure the network for use in accessing that service.
  • the tenant might input information of a domain name corresponding to the remote service.
  • each Orca in the network receives the domain name of this service and determines its distance (in terms of latency) to the service as described herein.
  • the Orcas are configured to share their latency information to the service on the network, and this shared latency information is used by the Orcas to determine the closest POP to the egress destination.
  • The‘closest’ POP is then designated as the current egress POP for that service. Subsequently, traffic received at any POP having the service as its egress destination is routed to the designated egress POP for provision to the service.
  • Orca is configured to include a probing agent configured for performance metric- based probing, but is not so limited.
  • Figure 22 is a block diagram showing probing operations of Orca, under an embodiment.
  • the performance metric-based probing includes for example DNS probing to translate every route domain name into an IP address, and advertise its results.
  • the performance metric-based probing also includes a latency probing agent configured to probe discovered IP addresses and report the latency for each of those addresses as described in detail herein.
  • Orca is configured to only probe the IP addresses it has discovered, and the probing period is configurable, but is not so limited.
  • Orca is configured to parse and write link state routing protocol messages in order to announce its DNS and latency data to other MCN components. The messages are sent in a single message, and Dolfins are configured to pass them to neighboring Dolfins to ensure they are received by other Orcas in the MCN.
  • the shared latency information is used by the Orcas to determine the closest POP to the egress destination, and the‘closest’ POP is designated as the current egress POP for that service.
  • the closest POP is determined as the POP having the shortest latency value relative to the egress destination, but is not so limited.
  • traffic received at any POP having the service as its egress destination is routed via the MCN to the designated egress POP for provision to the service.
  • Figure 23 is a block diagram showing an example determination of a designated egress POP, under an embodiment.
  • configuration information provided by the tenant includes data representing the“service” that is used by the tenant.
  • a distance (latency) of each POP relative to the “service” is determined by each Orca in the network, and then exchanged among Orcas.
  • the latency determined from POP A is 40 ms
  • the latency determined from POP B is 20 ms
  • the latency determined from POP C is 30 ms
  • the latency determined from POP D is 10 ms.
  • the closest POP to the “service” is POP D, and it is therefore selected as the egress POP for the“service”.
  • FIG 24 is a block diagram showing an example determination of a new egress POP in response to failure of a current egress POP, under an embodiment.
  • the current egress POP goes down.
  • the POPs are configured to designate a next-closest POP (to the service) as the new egress POP and reroute to the new egress POP the data destined for the service.
  • the remaining POPS re- evaluate distance (latency) of each POP relative to the“service”. For example, a new latency determined from POP A is 40 ms, a new latency determined from POP B is 20 ms, and a new latency determined from POP C is 50 ms. Therefore, the closest POP to the“service” is POP B, and it is therefore designated as the new egress POP for the “service”.
  • Each POP is configured to function as both an ingress POP and an egress POP. Consequently, in order to reconfigure tenant traffic for routing via the MCN instead of the public network on which it originated, the Orcas of an embodiment are configured to perform source network address translation (NAT) (SNAT) and destination NAT (DNAT). This is because, while the first and last mile couplings or connections use public IP addresses at the tenants and the POPs, the POPs use private IP addresses within the MCN. Therefore, the ingress POP is configured to perform DNAT that changes the destination address of ingress traffic from the public IP address of the egress destination to the private IP address of the egress POP corresponding to the egress destination. The ingress POP is also configured to perform SNAT comprising changing the source address of ingress traffic from the public IP address of the source tenant to the private IP address of the ingress POP.
  • SNAT source network address translation
  • DNAT destination NAT
  • the egress POP Following transmission via the MCN, and upon arrival of tenant traffic at the egress POP, the egress POP is configured to perform DNAT in order to change the destination address of the received traffic from the private IP address of the egress POP to the public IP address of the egress destination.
  • the egress POP is also configured to perform SNAT to change the source address of the received traffic from the private IP address of the ingress POP to the public IP address of the egress POP.
  • the ingress POP is configured to perform DNAT that changes the destination address of ingress traffic from the public IP address of the tenant to the private IP address of the egress POP corresponding to the tenant.
  • the ingress POP is also configured to perform SNAT comprising changing the source address of ingress traffic from the public IP address of the service to the private IP address of the ingress POP.
  • the egress POP Following transmission via the MCN, and upon arrival of service traffic at the egress POP, the egress POP is configured to perform DNAT in order to change the destination address of the received traffic from the private IP address of the egress POP to the public IP address of the tenant.
  • the egress POP is also configured to perform SNAT to change the source address of the received traffic from the private IP address of the ingress POP to the public IP address of the egress POP.
  • Figure 25 is a block diagram of an example traffic routing using address translation by Orcas at the ingress and egress POPs, under an embodiment.
  • the term “PublP” as used in this example includes public IP address, and“PrivIP” as used herein includes private IP address.
  • the source tenant TEN1 When a source tenant TEN1 is sending traffic to a destination TEN2, the source tenant TEN1 has knowledge of the public IP address of the nearest POP POP1, and it is configured to send traffic to this nearest POP (ingress POP) POP1 using the public IP address (pubIPl) of the ingress POP POP1.
  • the Orca at the ingress POP POP1 is configured to receive the traffic from the tenant TEN1 and perform DNAT to change the destination address of the ingress traffic from the public IP address of the egress destination to the private IP address of the egress POP (privIP2) POP2 corresponding to the egress destination.
  • the Orca is also configured to perform SNAT to change the source address of ingress traffic from the public IP address of the source tenant TEN1 to the private IP address of the ingress POP (privIPl) POP1.
  • the Dolfin of the ingress POP POP1 then routes the traffic via the MCN to the egress POP POP2, as described herein.
  • the Orca of the egress POP POP2 is configured to perform DNAT in order to change the destination address of the received traffic from the private IP address of the egress POP (privIP2) POP2 to the public IP address of the egress destination TEN2.
  • the egress POP POP2 is also configured to perform SNAT to change the source address of the received traffic from the private IP address of the ingress POP (privIPl) POP1 to the public IP address of the egress POP (pubIP2) POP2.
  • the traffic is then sent to the egress destination TEN2 via the WAN.
  • the current source tenant TEN2 When the original egress destination TEN2 is sending return traffic to the original source tenant TEN1, the current source tenant TEN2 has knowledge of the public IP address of the nearest POP POP2, and it is configured to send traffic to this nearest POP (ingress POP) POP2 using the public IP address (pubIP2) of the ingress POP POP2.
  • the Orca at the ingress POP POP2 is configured to receive the traffic from the tenant TEN2 and perform DNAT to change the destination address of the ingress traffic from the public IP address of the egress destination TEN1 to the private IP address of the egress POP (privIPl) POP1 corresponding to the egress destination TEN1.
  • the Orca is also configured to perform SNAT to change the source address of ingress traffic from the public IP address of the source tenant TEN2 to the private IP address of the ingress POP (privIP2) POP2.
  • the Dolfin of the ingress POP POP2 then routes the traffic via the MCN to the egress POP POP1, as described herein.
  • the Orca of the egress POP POP1 is configured to perform DNAT in order to change the destination address of the received traffic from the private IP address of the egress POP (privIPl) POP1 to the public IP address of the egress destination TEN1.
  • the egress POP POP1 is also configured to perform SNAT to change the source address of the received traffic from the private IP address of the ingress POP (privIP2) POP2 to the public IP address of the egress POP (pubIPl) POP1.
  • the traffic is then sent to the egress destination TEN 1 via the WAN.
  • Orca runs in a container (e.g., Docker container) as described herein, and the container is built or configured on top of the Open Network Operating System (ONOS), thus Orca is an ONOS application but is not so limited.
  • Orca is a component-based architecture that includes multiple components hosted in and supporting services of an application.
  • Figure 26 is a block diagram showing Orca components, under an embodiment.
  • the Orca components include but are not limited to a DNS and latency component, a configuration component (also referred to as an Address Resolution Protocol (ARP) component), a NAT component, and a firewall component. These components communicate with the provisioner to receive information of configured routes from the provisioner. The Orca components then process the set of configured routes to generate flow rules. The Orca components provide the flow rules to the flow rule manager.
  • ARP Address Resolution Protocol
  • the Orca configuration component communicates with the provisioner to receive configured routes for the corresponding network.
  • the configuration component receives a set of routes (e.g., r. vpn.com), and advertises the route information to the other Orca components.
  • the DNS/latency component performs DNS resolution to obtain the IP addresses corresponding to the routes, and measures or determines latency of the routes to the IP addresses.
  • the DNS/latency component also advertises the latency data of the IP addresses to the other Orcas of the MCN as well as to other MCN components (e.g., middleware, etc.), as described herein.
  • each POP is configured at any time to function as both ingress POP and egress POP.
  • the Orca NAT component performs the following steps:
  • SNAT/DNAT operations corresponding to the routes of the IP address. These operations include generating rules to perform DNAT operations that configure the POP as an egress POP for the destination address by changing the destination address of received traffic to be the public IP address of the egress destination.
  • the Orca will establish its own IP address as the source IP address. Subsequently, when the Orca receives from another
  • the NAT is configured as the egress POP to route the received traffic to that egress destination.
  • the SNAT/DNAT operations include generating rules to perform address translations (DNAT) that now configure the POP as an egress POP for routing traffic within the MCN.
  • DNAT address translations
  • These operations include the Orca establishing its own IP address as the source address, and performing DNAT in order to change the destination address of received traffic to be the private IP address of the new egress POP corresponding to the egress destination.
  • the firewall component of the Orca does not include any initial configuration information, and upon startup operates to block all incoming traffic attempting to access the MCN from public IP addresses.
  • route configuration information which includes public IP addresses associated with MCN tenants and their services, it maintains a list of the public IP addresses.
  • the firewall component subsequently allows traffic from the listed IP addresses to pass through the firewall into the MCN, while continuing to block traffic from all other IP addresses.
  • Operations of the Orca components generate instructions representing traffic flow rules, which are provided by Orca to a flow rule manager.
  • the flow rule manager which is a component of ONOS, is configured to translate the instructions received from Orca into OVS-defmed rules and write the translated flow rules to the OVS (e.g., using OpenFlow messages to the OVS).
  • the OVS installs the rules in tables, referred to as flow tables. Within each flow table of an embodiment the rules are prioritized so that, during routing operations, the rules are traversed according to the priority, but embodiments are not so limited.
  • the OVS subsequently uses the rules to control routing of corresponding data traffic as described in detail herein.
  • an incoming packet is first evaluated using the flow rules as embodied in a first flow table controlled by the firewall.
  • the parameters of the incoming packet are evaluated by traversing the rules in the first flow table, and when the parameters match the conditions of a particular rule then the packet parameters are forwarded to another OVS flow rule table specified by the matched rule.
  • This process is then repeated at each of a set of downstream tables as determined by the parameters of the incoming packet until routing parameters of the packet have been fully specified by the OVS flow rule tables.
  • Orca interacts with numerous MCN components, including but not limited to the provisioner, OVS, and Dolfin, as described in detail herein.
  • Figure 27 is a flow diagram of communications between Orca and other MCN components, under an embodiment. More particularly, Orca communicates with the provisioner to request route information of the network. Upon receiving the route information, Orca performs DNS resolution to obtain the IP addresses corresponding to the routes, measures or determines latency of the routes to the IP addresses, and instructs the OVS to send or propagate the latency data to other Orcas in the MCN.
  • Orca receives from the other Orcas in the MCN their latency data, and generates a table comprising the latency information of all Orcas in the network.
  • This latency table which is a dynamic table that is maintained and updated as data is received from other Orcas, is used by the Orca in making its determination of closest POP to an egress destination to be designated as the egress POP.
  • Orca communicates with the OVS (e.g., 00 VS, DO VS) and Dolfin.
  • Orca is configured to generate instructions representing traffic flow rules using route data received from the provisioner.
  • Orca is configured to cause the flow rules to be written to the OVS.
  • Communications between Orca and Dolfin comprise Orca receiving router status messages from its corresponding Dolfin. These router status messages include information regarding the status (e.g., up/down) of the other POPs in the MCN, but are not so limited.
  • Orca performs numerous functions according to pre-specified intervals. For example, Orca contacts a provisioner, in accordance with a polling interval Tl, and pulls routes as described herein. The routes are subsequently used to
  • Orca install/maintain the ingress/egress NAT table.
  • Orca is also configured to obtain a number of active data flows per tenant per route and, in accordance with a pushing interval T2, push the number of active flows to the web application. Further, Orca is configured to perform a status check of Dolfin, Watchdog, and the underlay network links according to a health check interval T4. Orca sends a message or notification to the provisioner if the status check indicates any of the components are not functioning.
  • the Orca of an embodiment is configured with a probing interval T3.
  • Orca generates probe packets to each of the public network routes and MCN routes, and the probe packets are configured to measure network parameters including one or more of latency, jitter, packet loss, and available bandwidth to name a few. If Orca determines, using data collected with the probe packets, that the public network has the best network performance, then it changes the NAT rules to forward packets via the public network instead of the MCN by changing output port. Conversely, if Orca determines that the MCN network has the best network performance, then it changes the NAT rules to forward packets via the MCN by changing output port.
  • the MCN components of an embodiment peer or provide connectivity with tenant networks or other components (e.g., routers, switches, routers, etc.) outside the MCN using route information learned from the tenant.
  • the MCN components are therefore configured to peer with external routers using existing protocols and automatically perform the route exchange.
  • Figure 28 is a block diagram showing POPs (e.g., S1-S4) coupled to communicate with an upstream (e.g., tenant) router, under an embodiment.
  • the POPs peer with external routers in the POP locations to form the geographically distributed topology.
  • Orca includes routing software that configures it as a
  • the routing software of an embodiment comprises Quagga, which is a routing software suite that provides implementations of Open Shortest Path First (OSPF) version 2 (OSPFv2), OSPFv3, and Border Gateway Protocol (BGP), among others, but embodiments are not so limited.
  • Figure 29 is a block diagram showing Orca comprising routing software (e.g., Quagga) coupled to communicate with the MCN and a tenant router, under an embodiment.
  • the use of Quagga along with ONOS (CON1), which includes applications and components that receive and use Quagga-transmitted routes, configures the controller as an FPM component.
  • CON1 ONOS
  • the infrastructure daemon of Quagga connects to the FPM on a predefined TCP port over a stream socket and transfers route change information over the connection.
  • Route entries from Quagga are broadcast to one ONOS and then to others (e.g., route advertisement from first gateway to first Quagga, to MCN, to second Quagga, to second gateway, etc.).
  • Each ONOS has knowledge of all IPs outside the MCN, and uses that information to route packets to the appropriate destination ONOS. In this manner Quagga is used to exchange routes between external networks and ONOS clusters.
  • the Orca performs NAT accordingly.
  • Dolfin is a core router or controller configured to make data routing decisions, and includes routing information regarding the egress destinations to which received data traffic is to be routed, and the routing protocol used to route the traffic to those egress destinations.
  • Dolfin receives a packet from a corresponding Orca gateway router.
  • the packet includes a private IP address of the egress POP corresponding to the egress destination of the packet, and this private IP address was provided by Orca prior to transmission of the packet to Dolfin.
  • Dolfin maintains a table including IP addresses and corresponding egress POPs, and uses the table to match the private IP address of the packet to a destination POP.
  • Dolfin determines the routing algorithm or behavior to be used for the packet as described in detail herein. Dolfin includes numerous routing behaviors for use in routing different types of traffic such that a routing behavior can be specified for each traffic class.
  • the traffic classes of embodiments are configured by each tenant based on attributes of the traffic in each class, but embodiments are not so limited. Using the configured traffic classes, Dolfin analyzes one or more parameters of the packet header information, and uses one or more of the parameters to determine the packet type (e.g., video, file transfer, etc.). Based on the determination of the packet type, Dolfin determines a routing behavior and a metric for use in routing the packet.
  • the routing behavior is determined using an objective function in combination with a link metric.
  • Dolfin periodically receives from its local Watchdog, link metrics that characterize its local links.
  • the link metrics corresponding to links of the MCN include but are not limited to one or more of latency, jitter, packet loss, and link utilization.
  • Dolfin propagates the link state of its local links to the other Dolfins of the network using link state update (LSU) messages that are periodically transmitted to the other Dolfins.
  • LSU link state update
  • Dolfin also receives link state data of the links corresponding to all other network Dolfins via LSU messages received from those other network Dolfins.
  • each Dolfin comprising the MCN has information of all links of the MCN. Using this link state information of all links in the network, each Dolfin generates and maintains its local version of the network topology corresponding to each link metric measured by the
  • a first input parameter includes an objective function, which is a mathematical combination of one or more metrics that produces a quantity representative of the quality of a link (e.g., latency, latency plus packet loss, etc.).
  • the second input parameter considered in the routing decision includes desired routing behavior.
  • the routing behaviors of an embodiment include but are not limited to routing packets via multiple-paths, routing packets directly via the shortest path, routing packets on a single-path and maintain the packets on that route unless there is a topology change or a variation in link qualities that exceeds a pre-specified threshold, and dropping packets. Therefore, as an example, the routing of an embodiment is shortest path routing based on latency. In another example, the routing is multi-path routing based on latency.
  • Each Dolfin separately controls routing of each traffic flow according to the data type of that flow and the routing behavior corresponding to that data type as described herein. Further, each Dolfin uses information of its view of the network topology to control traffic routing through the network for each traffic flow. When considering routing for each data flow, each Dolfin is configured to only control routing of traffic flows to the next hop in the network. Dolfin uses its view of the network topology to determine the current best route to the egress destination through the network, and then determines the optimal next hop from the current best route. Each successive Dolfin along the route traversed by the traffic flow similarly uses its view of the network topology to determine its optimal next hop node for routing the traffic flow.
  • Dolfin continuously reacts to new traffic flows by determining a traffic class for each traffic flow, deciding how to route the traffic based on the traffic class, and installing in the DO VS the flow rules to route that new traffic flow. Following installation of the flow rules, subsequent packets of this flow are routed directly by the DOVS, instead of Dolfin, in accordance with the installed flow rules.
  • Dolfin includes multiple components or subsystems, each of which communicates with various components of the MCN in configuring Dolfin to operate as the core router.
  • Figure 30A is a flow diagram of communications between Dolfin and other MCN components, under an embodiment.
  • a Dolfin configuration component communicates with the provisioner and, in response, receives the network configuration information for the corresponding tenant as well as the traffic class information configured for that tenant.
  • a routes component of Dolfin receives the IP addresses of the configuration information, and performs IP address matching in order to determine the private IP address of the egress POP corresponding to the egress destination of a traffic flow.
  • Dolfin further includes a traffic class component that receives the traffic class configuration information, and evaluates incoming traffic flows in order to match each flow to a configured traffic class. Based on the traffic classes, the traffic class component generates a set of routing behaviors that are translated into flow rules that are provided to the OVS (e.g., via OpenFlow). Because the flow rules are dynamic as a result of network topology changes, Dolfin continuously monitors the network topology and updates the flow rule information sent to OVS in response to network topology changes in order to ensure OVS includes the current instantiation of the flow rules.
  • a traffic class component that receives the traffic class configuration information, and evaluates incoming traffic flows in order to match each flow to a configured traffic class. Based on the traffic classes, the traffic class component generates a set of routing behaviors that are translated into flow rules that are provided to the OVS (e.g., via OpenFlow). Because the flow rules are dynamic as a result of network topology changes, Dolfin continuously monitors the network topology and updates the flow rule information sent to
  • Dolfin also receives flow rule information from its OVS, and this flow rule information includes data on amounts of traffic (e.g., packets, bytes, throughput, etc.) routed by each OVS flow rule.
  • Dolfin is configured to iteratively update flow rules of its local OVS and these updates, which occur periodically at a configurable frequency, are performed by each Dolfin for all rules installed by that Dolfin in its local OVS, but are not so limited.
  • Dolfin also includes a link quality component that is configured to communicate with Watchdog to receive and store the local link metrics or quality data (e.g., latency, jitter, packet loss, link utilization, etc.), and to update and maintain the link metrics data.
  • An OSPF component is configured to generate link state update (LSU) messages to propagate the local link metrics data to other Dolfins in the network, and to receive LSUs from the other network Dolfins.
  • LSU link state update
  • the OSPF component of Dolfin provides to the link quality and topology components (e.g., management plane, web app, WEB-UI, etc.), the route status or network link metrics information received from the other network Dolfins.
  • Dolfin is configurable to control Watchdog to report network metrics directly to other components, thereby relieving Dolfin of the responsibility of reporting metrics received from Watchdog.
  • An alternative embodiment moves the OSPF message sending and receiving from Dolfin and Orca to an external daemon, referred to herein as Sardine, which is configured for dedicated handling of OSPF messages.
  • Sardine is configured to run its own process and centralize the OSPF message creation, sending and parsing.
  • Figure 30B shows a POP configuration including Sardine, under an embodiment.
  • Figure 30C shows information flows involving the OVS bridge, Dolfin, and Sardine, under an embodiment.
  • Each POP includes its own Sardine, but is not so limited.
  • Sardine runs inside a container on a per-network (overlay) basis and sends all OSPF messages for that POP into the network.
  • Sardine is configured to expose an API to be used from Orca and Dolfin, which are configured to couple to and exchange messages with Sardine.
  • Orca and Dolfin provide local information (status of links and routes) and receive information from other POPs (status of links and routes).
  • Dolfin is configured to install rules for OSPF packet forwarding so that the packets are sent to Sardine.
  • Dolfin includes a topology component that is configured to generate a network topology snapshot using the link metrics data of the network. Dolfin uses the topology snapshot, which is continuously updated by the topology component, to make routing decisions.
  • a stats component of Dolfin collects from the Dolfin components data or information representing network behavior or state, and reports this information to one or more components of the management plane (e.g., monitoring subsystem, web app, user interface).
  • the network behavior information obtained from the Dolfin components and includes but is not limited to link status, link utilization, and full state of network. This information is displayed on the WEB-UI.
  • the network topology is the configuration associated with a MCN, and includes information of the Dolfins in the network, such as identifier, interfaces IP, subnets, ports and neighbor adjacency (hosts and routers), to name a few. Because every Dolfin on the network needs information about the network configuration, a global static topology file is sent to all Dolfins on startup.
  • the MCN In addition to the network topology, the MCN
  • components of embodiments share data of link state globally across the components of the network by exchanging messages, thereby enabling a link state view of the network.
  • the routing of traffic through the network includes use of an autonomous feedback control algorithm that is distributed among the network Dolfins and, as such, can be thought of as‘distributed’ because the operations and traffic routing decisions of each Dolfin are independent of those of every other Dolfin in the network. Further, given the link-state information, each router may independently perform the relevant routing computations.
  • Dolfins include data about the entire network topology because, for packet routing through the MCN, data of the destination Dolfin or POP is needed for a given incoming packet received at the corresponding ORCA, and this requires knowledge of the MCN routes over which each Dolfin on the network is responsible for delivery. Further, while links (sourceld, destinationld) and link state (utilization, latency, packet loss) are advertised using a dynamic link state routing protocol, Dolfins use knowledge of the subnets from source and destination in order to fully identify the link ports. Additionally, link capacity and interior gateway protocol (IGP) information is used by some routing behaviors during shortest path tree computations, and this data is dynamically distributed to support link updates.
  • IGP interior gateway protocol
  • FIG. 31 is a flow diagram of link discovery by Dolfins to discover ingress and egress links to neighbor Dolfins, under an embodiment.
  • Each Dolfin sends Hello messages to its links in order to discover neighboring nodes and to add the corresponding links of the neighboring nodes to its infrastructure.
  • Each Hello message includes an empty neighborList.
  • the Dolfin then adds an ingress link for each Hello message received from neighbor Dolfins, and adds those neighbors to their neighborsList.
  • a Dolfin determines if it is included on the neighborList of the received message, and if it is on the neighborList then is adds an egress link to the neighbor Dolfin corresponding to the Hello message.
  • the identification of adjacent Dolfins is realized using an exchange of Hello messages between the corresponding Sardines.
  • each Dolfin discovers its neighbor nodes and corresponding links. While each Sardine sends the Hello messages to its links in order to discover neighboring nodes, its corresponding Dolfin adds an ingress link for each Hello message received from Sardines of neighboring Dolfins, and adds those neighbors to their neighborsList.
  • a Dolfin Upon receipt of a Hello message by its Sardine, a Dolfin determines if it is included on the neighborList of the received message, and if it is on the neighborList then is adds an egress link to the neighbor Dolfin corresponding to the Hello message.
  • Dolfins send Route Updates to their discovered links, and Dolfins only accept these link-state updates (LSUs) from known devices.
  • Each Dolfin stores incoming and accepted LSUs, as well as its locally generated LSUs.
  • the data structure is created for the new device and added to the configuration data.
  • the stored LSUs for all devices are evaluated, and checked to determine if any link-state advertisement (LSA) has this new device as its destination. If positive, a new link is created from this stored LSU so LSUs will be accepted from this device.
  • LSA link-state advertisement
  • Dolfins then start receiving Route Updates from each known device and add the route updates to their configuration.
  • LSUs can include links to unknown devices, these unknown devices are stored, and links are added only when link source and destination are known.
  • the stored LSUs are evaluated and links are added from known devices to the new device.
  • Each Dolfin is configured to advertise to the entire network the subnets they route directly through their ports. In this manner each Dolfin starts to discover routes.
  • Figure 32 shows route advertisement among Dolfins, under an embodiment.
  • a route advertisement of an embodiment includes but is not limited to the Routerld, Networklp, Subnet and Port. The Routerld can route through its port to the subnet. If the Networklp is a host address, then that is also the Interfacelp of the Dolfin on that port.
  • LSAs link state advertisements
  • LSAs also advertise Link Subnets.
  • Each link endpoint (router interface) has an IP assigned to that subnet.
  • the subnet of an embodiment includes a point-to-point network, having at most two (2) host IPs (e.g., prefix length /30 or /31) including one for each router interface.
  • LSAs include information of SourceRouterld, DestinationRouterld and
  • LinkSubnet Both SourcePort and DestinationPort are used to create a link, so these are derived through determining (e.g., look up) for each Dolfin the port that is assigned to that LinkSubnet.
  • Each Dolfin of an embodiment advertises to the network its link properties, such as capacity and IGP.
  • Figure 33 shows link property advertisement among Dolfins, under an embodiment.
  • the Infrastructure Link Advertisement provides information of the
  • Routerld Port and the properties. Receiving Dolfins add these properties to the Neighbor information that Routerld knows.
  • Each Dolfin is provided with only the network configuration associated with that Dolfin.
  • the local network configuration data sent to a Dolfin therefore includes
  • Routerld Interfaces (Port, IP, Subnet), link to neighbor nodes (Link Infra Properties (Capacity, IGP), Link Port), and probing protocol packet Daemon (IP, Port).
  • Every Dolfin of the MCN is aware of every route. Routes are updated when a new host/switch connects to a Dolfin or when a routing table of a Dolfin is manually updated. Routes are advertised only when needed (e.g., new Dolfin added to the network, routing table updated on local Dolfin, following elapsing of a pre-specified period of time), but are not so limited. Route Packets are issued periodically.
  • a routing protocol packet (e.g., OSPF) is generated with a RouteUpdate type, and this packet floods the network.
  • a RouteUpdate includes a list of Route Advertisements for each subnet and IP on the routing table. The receiving Dolfins update their routing tables using data of the packet, and forward the packet. While flooding in an
  • embodiments happens to new Route Updates (related to packet sequence number, age and previously seen Route Update packets), flooding is optional because other methods can be used to provide the Route Updates information to the Dolfins.
  • Each Dolfin is aware of the qualities for its links.
  • Infrastructure Link Packets are issued periodically.
  • a routing protocol packet e.g., OSPF
  • An InfraLinkUpdate includes a list of Infrastructure Link Advertises for each link on the Dolfin interfaces.
  • the receiving Dolfins update the link qualities using the packet InfraLinkAdvertisement, and forward the packet. Flooding in an embodiment happens to new Infra Link Updates
  • flooding is not needed if the triggering event is a new Dolfin added to the network (packet can be sent to the new router, which results in receipt of an acknowl edgement) .
  • Every Dolfin maintains a map of Dolfm-to-Dolfin information. Every Dolfin generates or builds and updates a RoutingTable.
  • the RoutingTable data structure is used to help the handling of incoming packets so that, given an IP destination address, the Dolfin to which the packet is to be forwarded is known.
  • the RoutingTable is updated after each RouteUpdate packet. DeviceConfigurationManager also updates the
  • RoutingTable for Hosts subnets connected to the switch is the RoutingTable for Hosts subnets connected to the switch.
  • the Dolfins of an embodiment are configured to control a routing pipeline to achieve both network traffic flow classification for statistics generation, and routing with different behaviors and one or more metrics based on the traffic classification result, as described herein. While HALO is used to control packet routing, an embodiment applies the most suitable routing behavior of HALO by classifying the packet as pertaining to a certain user-defined class of network traffic.
  • a traffic class is a configuration input into the system that specifies how a certain type of traffic should be routed.
  • a traffic class includes two components, selector and behavior. Selector specifies the characteristics of the flow that would match this traffic class. The selector also specifies different patterns to be matched to classify a flow as part of this traffic class. Those patterns can be either 5-tuple like matching or DSCP code values.
  • Behavior which specifies how to route the traffic classified as this traffic class, includes two components, a routing algorithm and an objective function.
  • Embodiments of HALO include multiple routing algorithms, which define the different ways flows can be routed, including routing packets via multiple-paths, routing packets directly via the shortest path, routing packets on a single-path and maintain the packets on that route unless there is a topology change or a variation in link qualities that exceeds a pre specified threshold, and dropping packets.
  • routing algorithms (with the exception of dropping packets) rely on having a corresponding objective function that provides a metric to evaluate a link weight and build the topology shortest paths trees.
  • the mathematical objective function takes link quality metrics as input and provides a weight as an output.
  • the objective functions use the available metrics (e.g., link utilization, latency, jitter, packet loss, IGP), and combine them in different ways to the objective functions provided to be used on the behaviors.
  • the Dolfin traffic class subsystem is configured to determine the traffic class of received traffic, and to generate the OVS tables and flow rules to ensure that the different flows are routed as specified by their corresponding traffic class.
  • the traffic classes for each tenant are derived from information of applications accessed by that tenant over the core network.
  • Each tenant configures the MCN by adding or specifying information or data of the different data traffic and applications they want to classify, and the way in which they want their traffic or packets handled.
  • a class of an embodiment is defined by specifying a protocol, ports, and the type of routing used for the class. Additionally a name can be included for ease of identification.
  • An example of a class definition is as follows: name“video conference”; protocol“UDP”; ports “4000-5000”; handling“low latency path”).
  • Another example of a class definition is as follows: name“file transfer”; protocol“TCP”; ports“22”; handling“high throughput”).
  • the traffic flow rules are configured to follow a pipeline processing-based approach (e.g., OpenFlow).
  • a flow rule dedicated to that flow which leads to a large number of rules that can be a burden on network memory.
  • Embodiments therefore include traffic class table trees (TTTs) to manage the OVS rules used in making routing decision while reducing a size of the rule set.
  • TTTs which are implemented in the OVS, enable a large number of rules to be implemented in a hierarchical series of smaller tables, instead of a single table housing all rules. ETsing the TTTs, a traffic flow is pipelined through a series of tables, and the resulting flow rule is obtained as the Cartesian product of a single matching entry from each tree. This pipelining of packets through the TTTs therefore provides the equivalent of a single flow rule while requiring the network to maintain fewer flow rules, thereby enabling implementation of relatively larger rule set with significantly less processing overhead.
  • the traffic flow rules are placed into the OVS in multiple tables, and a rule comprises its table number, a selector, and a set of actions, but is not limited to these parameters.
  • the table number of a rule includes an identifier of the table to which the rule should be installed.
  • the selector of the rule defines the packets that match the rule, and can also specify different expected parameters for a packet (e.g., L4 protocol, L4 ports, ethernet packet type, source subnet, destination subnet, etc.).
  • the action of the rule includes the operation or sequence of operations to be performed on the packet. The operations include, for example, modifying the packet values, pushing the packet out on a physical port, and/or dropping or sending the packet to another table where it is matched with rules from that table, but are not so limited.
  • Embodiments organize the traffic flow rules by generating a tree to include the user-configured classes, thereby reducing the number of required rules as well as making it easier to generate statistics for all classes.
  • Figure 34 is an example rule tree, under an embodiment.
  • An embodiment further generates a table tree that includes multiple tables of rules arranged in a tree structure, as described in detail herein. Matching on the tree comprises use of multiple rules spread across different tables, so an embodiment places or divides the rules into tables as described herein.
  • Figure 35 is an example rule tree, under an embodiment. Through use of multiple tables, and configuring rules to forward packets from table to table, embodiments simplify computations used to classify and generate statistics for the flows.
  • a TCP packet on port 22 is received, it is forwarded to Table 1 and match according to the TCP flow, which forwards the packet to Table 2.
  • the packet matches port 22 rule, which forwards the packet to Table 4.
  • the system is configured to write rules with source and destination subnets, and the leaf rules on the same table generally follow the same type of behavior. These leaf rules route the packet according to the desired behavior.
  • Embodiments track the rules installed for each traffic class and, further, make use of flow statistic messages received (periodically) from the OVS to generate and retain per-class metrics. More specifically, each rule tracks the number of bytes and packets on which it operates (e.g., matches), and is thus configured to identify the statistics about the different protocols and ports. For example, to check how many TCP packets were routed the system analyzes data of the Table 1 TCP rule, as all TCP packets passed through that rule. Further, to check on how many TCP packets were routed via port 22, the system analyzes data of the Table 2 port 22 rule.
  • the tree of tables of an embodiment in addition to maintaining the capability to route using different approaches, simplifies the identification and classification of the different network flows being routed. Organization of the flows into tables also greatly simplifies the addition and removal of new classes of network traffic, which can be performed by simply adding or removing new tables and nodes linking to those tables.
  • Dolfin controls routing of traffic using HALO and its routing behaviors along with information of numerous different traffic classes as described herein, and in so doing it associates with each traffic class a specific objective function that models the routing behavior of that particular traffic class.
  • the objective function operates using one or more particular link metrics to identify least-cost paths in the network, and the link metric(s) to which each particular objective function is applied is therefore based on the sensitivity of the corresponding routing behavior to that metric(s).
  • Dolfin performs traffic identification and classification, and implements the objective functions corresponding to the traffic classification.
  • Dolfin comprises four traffic classes including Expedited Forwarding (EF), Assured Forwarding (AF), Best Effort (BE), and Network Control (NC), but is not so limited.
  • EF Expedited Forwarding
  • AF Assured Forwarding
  • BE Best Effort
  • NC Network Control
  • the objective function of each traffic class operates on a prioritized hierarchy of link metrics to identify the least-cost paths in the network.
  • the prioritized link metric hierarchy (default) for the Expedited Forwarding traffic class is latency, jitter, loss, utilization, and cost, but is not so limited.
  • the routing behavior of the expedited forwarding traffic class is aimed at latency-sensitive traffic.
  • the shortest path routing behavior is dynamic and reacts quickly to network changes, thereby ensuring that the flows stay on the best path while avoiding unrestrained or uncontrolled oscillations in routing.
  • link cost function (Latency + k * Jitter)
  • traffic is routed along the path of least latency, adding a penalty for jitter on the links.
  • the weight k placed on jitter is configurable.
  • the prioritized link metric hierarchy (default) for the Assured Forwarding traffic class is loss, latency, jitter, utilization, and cost, but is not so limited.
  • the routing behavior of the assured forwarding traffic class is aimed at minimizing loss in order to support loss-sensitive traffic.
  • the Sticky routing behavior is used to avoid moving the flow, which can induce temporary loss. Setting the link cost to the negative log of packet survival rate (1 - loss rate) (link cost function -ln(l-LosslOO)), traffic is routed along a route with the minimum cumulative loss rate. Loss accumulates multiplicatively, while the MCN algorithms evaluate sequences of links additively.
  • the least-cost path ends up being the path that maximizes the cumulative survival probability for transmitted packets.
  • Packet loss rate can be noisy, so an embodiment considers an average of samples from a pre-specified time interval (e.g., one (1) second, etc.), weighted by packet count.
  • the prioritized link metric hierarchy (default) for the Best Effort traffic class is cost, utilization, loss, latency, and jitter, but is not so limited.
  • the routing behavior of the best effort traffic class is configured for lower-priority bulk traffic.
  • An embodiment balances the traffic over multiple network paths. Cost plays a role in incentivizing routing that avoids premium links, so embodiments use a link cost function (Cost *Capacity/(Capacity - Utilization)) but do not consider the link quality metrics loss, latency, and jitter for bulk traffic.
  • the utilization factor which in an embodiment represents the M/M/l queue delay, incentivizes the routing to avoid congesting paths, and to avoid adding bulk traffic to the paths already in use by higher-priority traffic.
  • the prioritized link metric hierarchy (default) for the Network Control traffic class is latency, loss, jitter, utilization, and cost, but is not so limited.
  • the WEB-UI is configured to enable a tenant to input or change (from the default) a priority order of link metrics for one or more of the different traffic classes.
  • the MCN of an embodiment can be configured to enable a tenant to assign a weight to one or more link metrics, where the weights are used in lieu of the link metric priorities.
  • the routing process for incoming traffic involves Dolfin determining a class of the traffic using one of user-defined classification parameters, Differentiated Services Code Point (DSCP) -based parameters, or automatic classification.
  • DSCP Differentiated Services Code Point
  • Dolfin is configured to identify traffic classes by applying the user-defined traffic classification parameters.
  • the user-defined parameters include, for example, IP range (e.g., source IP, destination IP), port range, and protocol identifying information, but are not so limited.
  • the WEB-UI is configured for use by a tenant to input configuration data relating to supported traffic classifications, including providing a combination of five-tuple values (e.g., source IP address, destination IP address, source port, destination port, protocol), and in advanced cases, the Layer 7 application or URL.
  • five-tuple values e.g., source IP address, destination IP address, source port, destination port, protocol
  • the tenant-configured DSCP values take precedence in classifying traffic, but embodiments are not so limited.
  • the WEB-UI further includes a setting to disable the default classification so that the traffic is routed using the DSCP value of the packet.
  • the WEB-UI can also be configured for use in setting whether the traffic default classification is to be applied permanently, or if it is to be applied only while the traffic is traversing the MCN such that the original DSCP value is restored when the traffic egresses the MCN.
  • the determination of traffic class using user-defined parameters comprises classifying incoming traffic using information provided by the tenant via the web UI, as described herein.
  • Dolfins are configured via a REST API with traffic class data.
  • the traffic class data is integrated into the ONOS API, but embodiments are not so limited. Identification of classes is performed based on one or more traffic attributes including protocol (TCP or UDP), ports (range of ports (source and destination)), source (IP of the source originating the packets), destination (final destination IP of packets), and behavior (configured behavior for flows matched by this class).
  • Embodiments extend the configuration fields to include destination port, and differentiated services (DSCP) field, but are not so limited.
  • Dolfin Upon detecting a new flow, Dolfin is configured to perform a comparison with the configured traffic classes, and a decision is made on how to route the flow.
  • a top-level flow table matches on these fields and forwards traffic to separate tables corresponding to each traffic class, but is not so limited.
  • Traffic classes are controlled differently based upon tenant configuration data or parameters.
  • the tenant also provides the behavior expected for a traffic class.
  • the available routing options of HALO include one or more of multiple-path routing, Sticky (packets are routed via a single path and are not moved unless there is a topology change), shortest path (packets are routed directly through the shortest path), and DROP (packets are dropped), as described herein.
  • HALO uses a corresponding metric (e.g., delay, congestion, latency, etc.) as an input to the selected routing behavior.
  • Dolfin in the absence of user-defined traffic classes, is configured to identify traffic classes according to the differentiated services code point (DSCP -based) information in the corresponding traffic header and corresponding protocol/port range.
  • the MCN is configured to check the DSCP values of incoming packets and classify the packet as belonging to a class of traffic with a particular priority.
  • the MCN can also be configured to use additional deep packet inspection-based traffic detection functions to identify a type of traffic, and to verify and mark the DSCP code point values
  • the DS field in the packet header specifies a per-hop routing behavior of the corresponding traffic, and Dolfin is configured to use this DSCP information to control routing behavior by assigning corresponding traffic classifications.
  • the MCN is configured to mark the packet with a default classification based on the following: VPN traffic with source or destination packets with Port numbers 500, 4500, and SSL VPN (443) is marked as Assured Forwarding class; traffic that would be under a data transfer class (e.g., FTP, SCP, SSH, etc.) is marked as Assured Forwarding class; general Internet bound traffic (e.g., HTTP (port 80), and DNS (port 53)) is marked as Best Effort class; real time voice and video traffic with Port numbers for SIP (5060, 5061), RTSP (554), RTP (5004), and RTCP (5005) is marked as Expedited Forwarding class; speedtest type traffic is marked as Expedited Forwarding class
  • the DSCP-based traffic classification comprises mapping traffic into traffic classes according to a hierarchy that includes use of a custom override mapping, differentiated services field mapping, source port field mapping, and default mapping.
  • the hierarchy of an embodiment is a decreasing hierarchy, but is not so limited.
  • the mappings are configurable from the front-end via one or more configuration APIs, as described in detail herein.
  • the MCN specifies or defines routing behavior using a routing algorithm/objection function (link cost) pair, and the Dolfin and the middleware have shared knowledge of the available routing behaviors.
  • the WEB-APP is configured to present via the WEB-UI a list of the behaviors available for use.
  • the configuration APIs are further configured for use in adding new traffic classification mappings.
  • embodiments In response to a new classification mapping, embodiments generate an identifier that specifies the desired routing behavior, and the Dolfin creates a new traffic class configured with the selected algorithm and cost function parameters of the routing behavior.
  • Classification using the custom override mapping is configured to map traffic to a traffic class using a match on any subset of N-tuple values (where N represents a pre- specified variable).
  • N represents a pre- specified variable
  • the custom override matches on any subset of 5-tuple values (Source IP, Destination IP, Source Port, Destination Port, Protocol).
  • the N-tuple values are provided by the tenant or administrator, but are not so limited.
  • Traffic classification using the differentiated services (DSCP) field mapping comprises use of the 6-bit value present in the corresponding packet IP header.
  • Embodiments include a default mapping from DSCP values to traffic classes and, optionally, include a reconfigurable mapping (front-end).
  • the classification of traffic using the source port field mapping includes use of the 16-bit value in the UDP/TCP packet header.
  • Embodiments include a default mapping from source port to traffic classes and, optionally, include a reconfigurable mapping (front-end).
  • Default traffic classification is used when a match is not found for a packet in any configured mapping.
  • the default traffic classification comprises routing the flow through the Best Effort class, but is not so limited.
  • Dolfin is further configured to perform automatic classification of traffic as described herein.
  • Automatic classification is used to determine traffic routing behavior in the absence of user-defined classification parameters and DSCP -based information. This automatic classification is based on IP range (e.g., source IP, destination IP) and port range, for example.
  • Dolfin identifies the objective function corresponding to the traffic classification.
  • the objective function models the routing behavior of the traffic, thereby controlling the routing behavior of the traffic.
  • Multiple paths exist between source and egress destination, and the routing of an embodiment is configured to use one or more paths for routing data (e.g., all paths, set of paths, etc.). While an embodiment uses or invokes multi-path data routing, as described in detail herein, embodiments are not so limited as the MCN components are not limited to including or using any particular type of routing.
  • Dolfins are configured to provide multiple policy -based routing algorithms for use in routing data. For example, a particular user can specify policy -based routing based on latency, so that routes having the lowest latency are used to route the corresponding data. In another example, a particular user can specify policy -based routing based on data throughput, so that routes having the highest throughput are selected for routing the corresponding data.
  • the POPs of embodiments control routing with user-specified objective functions or policies, or combinations of selected policies.
  • the traffic routing of embodiments generally operates by finding least-cost paths in the network, where the lowest cost path is determined based on one or more link metrics such as packet loss, jitter, latency, throughput, and utilization as described herein.
  • the cost of a path is defined as the sum of the costs of the links that comprise the path, so each link in a network has an associated numeric or link cost that produces routing behavior matching tenant needs and expectations. Embodiments therefore take into account any combination of link properties when computing the cost of a link, and in response produce a single, positive real-valued cost.
  • the objective functions are configured to calculate link cost for the links in the network.
  • an objective function uses the corresponding link metrics (e.g., packet loss, latency, jitter, etc.) for the particular link to determine or calculate the link cost of that link. Dolfin then evaluates the link costs of all links in the network to determine a“best” path through the network from ingress POP to egress POP for a traffic flow, where the“best” path is the path that minimizes the link cost.
  • the objective functions of an embodiment are configurable or reconfigurable by tenants desiring custom objective functions for use in routing their traffic, but are not so limited.
  • link quality metrics include latency, which as used herein is determined using the round-trip travel time over the link (milliseconds).
  • Link quality metrics also include jitter, which as used herein includes variation in the round-trip travel time over the link (milliseconds (ms)).
  • link quality metrics include loss, which as used herein includes the loss rate on the link, as a percentage of packets lost.
  • Link quality metrics also include utilization, which as used herein includes the traffic rate on the link, specified in terms of a bitrate.
  • Link quality metrics of an example embodiment are reported every 100 ms, with the exception of utilization, which is reported every 250 ms, but the embodiments are not so limited.
  • static properties of each link are considered in embodiments.
  • the static properties include capacity, which as used herein includes the maximum traffic capacity of the link (bitrate).
  • Static properties also include interior gateway protocol value, which as used herein includes a fixed cost configured for the link. Therefore, while embodiments can take into account any combination of link properties when computing the cost of a link, the resulting output is a single, positive real-valued cost.
  • the link cost function is paired with a routing algorithm to define routing behavior.
  • the routing algorithms of HALO include multi-path, shortest path, and Sticky routing behaviors.
  • the shortest path routing behavior is configured to select a least-cost path for the traffic, and the traffic is re-routed to a lower cost path if such a path is subsequently identified.
  • the Sticky routing behavior is configured to select a least-cost path for the traffic at the time when traffic flow starts, and keeps the traffic on the selected path unless a significant network change occurs (e.g., link or node coming up or going down), in which case the least-cost path is recomputed and the traffic is moved to the new least-cost path.
  • the multi-path behavior continuously balances traffic over multiple paths, converging to a state in which all traffic is taking a least-cost path.
  • Routing behavior is defined by pairing a routing algorithm with a link cost function as described herein. Traffic routed through the MCN is assigned one of a number of traffic classes, and differentiated treatment of traffic belonging to different traffic classes based on current network conditions provides an important feature in a dynamic real-time network like the MCN. Therefore, to understand the routing behavior produced by the link cost functions, the behavior of the routing algorithms is also considered.
  • the HALO routing algorithm continuously balances traffic over multiple paths, converging to a state in which all traffic is taking a least-cost path.
  • the Sticky algorithm which is a routing behavior of HALO, selects a least-cost path for the traffic at the time the traffic starts flowing, and keeps the traffic on that path until such time as a significant network change occurs (e.g., link or node coming up or going down) at which time the least-cost path is recomputed and the traffic is moved onto the new path.
  • the shortest path routing behavior selects a least-cost path for traffic, and if the selected path changes then the traffic is moved.
  • the HALO algorithm provides a routing solution that retains the simplicity of link-state, hop-by-hop protocols while iteratively converging to the optimal routing assignment.
  • HALO comprises a novel link-state routing solution with hop-by-hop packet forwarding that minimizes the cost of carrying traffic through packet-switched networks.
  • hop-by-hop means that each router, based on the egress destination address, controls only the next hop of a packet as it traverses the core network.
  • Adaptive refers to the algorithm not requiring the traffic demand matrix as an explicit input in order to compute link weights.
  • the algorithm seamlessly recognizes and adapts to changes in the network, both topology changes and traffic variations, as inferred from the network states like link flow rates.
  • the term“link state” as used herein means each router receives the state of all network links through periodically flooded link-state updates and makes routing decisions based on the link states.
  • the term“optimal” as used herein refers to the routing algorithm minimizing some objective or cost function (e.g., minimize total delay) determined by the network operator.
  • HALO independently and iteratively updates the fraction of traffic routed to the destination node and leaving the source node on each of its outgoing links.
  • This“fraction of traffic” is represented using“split ratios”, as described in detail herein.
  • Embodiments measure time in units of iterations, and each iteration is defined by a cycle comprising the flooding of existing link states through the network followed by updating of split ratios at every POP, which modifies the link states for the next iteration.
  • the updates are calculated per iteration based on the best path to each destination as determined by the marginal costs of the network's links.
  • HALO converges to the routing configuration that minimizes the cost of the network. Furthermore, HALO is adaptive and automatically converges to the new optimal routing assignment for quasi-static network changes.
  • the selections at each POP relating to which or how many packets follow a select next hop through select nodes is termed a“split ratio” as described herein.
  • the split ratio determination performed at each POP generally comprises each node checking to see whether it has traffic to a given destination. If it does not already have traffic going to a destination, it forwards all newly received packets to that destination along the shortest path to that destination. If it does already have traffic going to a destination, it adjusts the fraction of traffic it forwards along its different outgoing links according to the split ratio equations. This process is iteratively followed until the optimal solution is obtained.
  • each iteration is defined by the flooding of existing link states through the network followed by every router updating its split ratios, which modifies the link states for the next iteration, as described herein.
  • embodiments iteratively adjust the split ratios at each router, and move traffic from one outgoing link to another in accordance with the adjusted split ratios. This only controls the next hop on a packet's path leading to hop-by-hop routing.
  • the split ratio adjustments comprise increasing the split ratio to the link that is part of the shortest path at each iteration, even though the average price via the next-hop router may not be the lowest.
  • Split ratios are also adapted dynamically and incrementally by decreasing a ratio along links that belong to non-shortest paths while increasing a ratio along the link that is part of the currently calculated shortest path at every router.
  • the calculation of split ratios at each POP comprises computing or determining the shortest path tree to a destination POP, and then calculating branch cardinality for the shortest path by calculating a product of the number of branches encountered in traversing this shortest path tree. Branch cardinality is used to make sure that nodes that are farther away from a destination node are more conservative in how much traffic they shift to the shortest path leading to the destination.
  • a traffic shift rate is determined at which traffic to the POP will be dynamically shifted from a more‘expensive’ link to the link with the lowest cost or shortest path.
  • a split ratio update factor is calculated by dividing the traffic shift rate by the total rate of
  • the updated split ratio is calculated by multiplying the current split ratio and the split ratio update factor, and dividing the result by the branch cardinality.
  • the physical time needed to complete an iteration generally does not adversely affect the results except in situations in which the network state changes very rapidly within the physical time.
  • the split ratio updates are made using a step-size selected to allow changes in split ratios to be reflected in the link rates prior to a next iteration.
  • Step size is the unit of control with which the calculated changes in the split ratios are multiplied to determine how much to vary the split ratios from one time slot to the next, and is generally controlled to enable the network to approach a stable operating point.
  • the step size of an embodiment is generally selected to be inversely proportional to the load.
  • the step size can be decreased as the optimal routing assignment is approached, but embodiments are not so limited, as use of a small enough but constant step-size causes routes to stabilize at a point closely approximating the optimal routing assignment.
  • alternative embodiments use larger step-sizes to increase the speed with which the routing approaches or converges to the optimal solution. While larger step-sizes may be prone to oscillations that can possibly slow convergence to optimality, small oscillations are acceptable and have little or no adverse impact on overall network convergence to optimality. Because time is measured in units of iterations, the time for the network to converge to the optimal routing solution depends upon the step-size used in each iteration and, additionally, the physical time needed to complete an iteration. In fact, the need to converge to the optimal routing assignment before the traffic changes means that routers are restricted in how long they have for each iteration.
  • the time required to complete an iteration depends at least in part on the frequency of the link state updates throughout the network.
  • the POPs comprising the core network are operating independently or asynchronously in performance of the global link state updates. Therefore, the link state data is shared asynchronously among the POPs such that each POP is sending its link state data and receiving link state data asynchronously relative to the other POPs of the core network.
  • Embodiments therefore consider the asynchronous link state updates when controlling or setting a frequency of link state updates in the core network. While the time needed to flood link states across the network or to update the routes according to split ratio calculations is relatively short, numerous iterations might be needed to converge to the optimal solution depending on the selected step-size. Consequently, embodiments are configured to use relatively high- frequency link-state updates throughout the core network in order to provide adequate convergence times.
  • the sticky flow or sticky behavior includes a type of traffic class behavior applied to flows that should stick to the same path until some reaction trigger is activated.
  • the sticky behavior is therefore used to manage flows that could suffer performance loss by switching paths, and is configured to avoid path switching if possible.
  • numerous conditions are considered when determining when the network is considered to have fundamentally changed so that sticky traffic is moved to a recalculated least-cost path.
  • the network is determined to have changed when a latency change is detected that is at least X% (e.g., 10%, etc.) and at least an absolute change of Y ms (e.g., 50 ms, etc.).
  • the network is determined to have changed when a jitter change is detected that is at least X ms (e.g., 15 ms).
  • the network is determined to have changed when a loss change is detected that is at least X percentage points (e.g., two (2) percentage points, etc.).
  • Sticky flow re-computation is triggered in response to significant latency, jitter, or loss changes. However, re-computation should occur in response to a sustained change in the conditions on some link, and not in response to a single-sample spike or drop in particular metric.
  • An embodiment compares medians of consecutive time intervals. The intervals are configurable, but are not so limited. For example, if X represents the median of samples from a first half of an interval, and Y represents the median of the samples from the second half of the interval, then re-computation would be triggered in response to a significant change between X and Y.
  • the link metrics are reported to a Dolfin by its corresponding Watchdog, but not all data samples are shared with or provided to other Dolfins in the network through the OSPF messaging packets.
  • Another embodiment compares compute-time conditions by recording for each flow the iteration/timestamp at which its least-cost path was computed.
  • the topology snapshot for each such iteration/timestamp is also maintained in memory.
  • a comparison is performed between the link metrics in each snapshot and the current link metrics. Any snapshot deemed to be significantly different from the current network conditions is cleared out, and all associated flows have their least-cost path recomputed on the current snapshot.
  • This process detects both sudden and gradual significant changes in link metrics, and can also apply some noise-reduction such as working with medians of samples to avoid re-computation in response to single-sample spikes. This process avoids potential scaling issues with the number of flows, since maintenance of old snapshots in memory and comparison of each one with current network conditions could become both time- and memory- intensive.
  • Another alternative embodiment detects significant changes in path-cost by tracking the path cost associated with each flow, instead of attempting to detect a change in a link metric. If the least-cost path in the current network is cheaper by some configured percentage, then the sticky flow is shifted over to the“cheaper” link. This process detects both sudden and gradual changes in the path cost, and also checks against the median of the path cost over a few successive network snapshots to avoid responding to short-lived spikes or drops.
  • embodiments Upon determining a best path for each traffic flow using link metrics available at the time the flow is assigned to a path, embodiments route the traffic via that best path. Once routed over a particular link, the traffic is maintained on the selected route until occurrence of an event necessitates rerouting of the traffic. Data of routing and routing changes is logged, and this logged data includes information of the full flow, the old path, the new path, and time stamps for flow start and the flow change event. When configured for packet-based routing, the metrics are evaluated for each packet routed or forwarded.
  • An event that results in rerouting includes deterioration of link conditions
  • Another event that results in rerouting traffic over an alternative link includes the occurrence of a new flow having a higher priority traffic class, where routing of the new flow over the same link as the lower priority flow will exceed the traffic utilization as determined by the corresponding routing algorithm.
  • Traffic rerouting is also initiated as a result of an increase in utilization of a route.
  • the increased utilization results from changes in throughput on a path among flows sharing that path. This event triggers a re-evaluation of the distribution and flows while attempting to keep higher traffic class/priority on their current path.
  • the MCN components are configured to first move traffic flows having a smaller/lower bandwidth. This reduces the aggregate network impact by moving a lower bandwidth flow to a potentially higher latency path.
  • MCN components are configured to use link metrics to determine link status regarding blackout and brownout conditions as described herein.
  • Link status of embodiments is probed periodically (e.g., once per second, once every five (5) seconds, etc.) to determine link up/down events, traffic utilization percentage (e.g., separate traffic directions, bidirectional), latency on a link (ms) (e.g., separate directions, RTT), jitter (ms) (e.g., separate directions, RTT), throughput (Mbps) (separate directions, bidirectional), and packet loss (percentage) (e.g., separate directions, bidirectional).
  • traffic utilization percentage e.g., separate traffic directions, bidirectional
  • latency on a link e.g., separate directions, RTT
  • jitter e.g., separate directions, RTT
  • Mbps throughput
  • packet loss percentage
  • the link probing (e.g., latency, jitter, packet loss) is performed per each traffic class in order to develop hop-to-hop network metrics for each traffic class.
  • the probe frequency and traffic classes to be probed are configurable by the corresponding tenant for a specific network.
  • the MCN is configured to log information or data of all link probes, and the WEB-UI is configured to display or present this probing information using real-time graphs.
  • Embodiments include a“Quick Probe” setting configured to control a frequency of link probing.
  • this setting includes a control for separately setting probe times in sub-second increments (e.g., one (1) ms to one (1) second increments) for each respective traffic class. Therefore, for example, the Quick Probe control is configured to set a faster probe frequency for a first traffic class (e.g., Network Control), while disabling probing of a second traffic class (e.g., Best Effort).
  • a“Quick Probe” setting configured to control a frequency of link probing.
  • this setting includes a control for separately setting probe times in sub-second increments (e.g., one (1) ms to one (1) second increments) for each respective traffic class. Therefore, for example, the Quick Probe control is configured to set a faster probe frequency for a first traffic class (e.g., Network Control), while disabling probing of a second traffic class (e.g., Best Effort).
  • a first traffic class e
  • PDLTs probe protocol data units
  • Embodiments include use of an MCN signature on probe packets so that they are distinguishable from actual data traffic.
  • the metrics determined by link probing are not affected by issues relating to status (e.g., congestion) and/or availability (e.g., process down) of the OVS daemon at a POP.
  • Embodiments also account for packets dropped due to rate limiting functions on a link/at a POP separately from actual link PDU/packet loss. Further, numbers of probe packets as well as throughput/bandwidth consumed by probe packets are separately accounted for in network metric logs and reports.
  • Links are probed periodically as described herein, and when a change is detected in a link metric that might necessitate rerouting of traffic to an alternative link, the probing of the current link is repeated a specified number of times before the traffic is rerouted.
  • MCN components trigger rerouting of the traffic from the current link to the next best route.
  • An embodiment includes a default value of three (3) for the number of times to repeat probes, but is not so limited. Alternatively, the number of repeated probes is configurable by a tenant.
  • the metrics of the link are re-evaluated over the specified number of probes prior to using the link to route any traffic.
  • the change in link metrics of an embodiment is calculated using a baseline that is a mean/average link metric value (e.g., latency) over a specified preceding period of time (e.g., past 24 hours, etc.).
  • the period of time used in calculating the baseline value is configurable, but is not so limited.
  • the link metrics of the alternate path are evaluated to determine that they are in fact improved relative to those of the current route in order to avoid rerouting traffic to a bad link.
  • the evaluation of the link metrics of the alternate route includes link data of at least the configured number of repeated probes, but is not so limited.
  • Embodiments include default parameters for triggering failovers.
  • the default parameters for failover based on latency include triggering a failover to the best alternate path for any change in latency that exceeds a specified percentage (e.g., ten (10) percent, etc.) of the baseline latency and more than a specified value (e.g., 50 ms, etc.). For example, if the current route latency increases by ten percent, but the increase is less than 50ms, the traffic is maintained on the current route.
  • the default parameters for failover based on jitter include triggering a failover to the best alternate path for any change in jitter that exceeds a specified value (e.g., 15 ms, etc.) is configured to trigger a failover to the best alternate path.
  • the default parameters for failover based on packet loss include triggering a failover to the best alternate path for any change in packet loss that exceeds a specified percentage (e.g., two (2) percent, etc.) is configured to trigger a fail
  • the default parameters for triggering failovers in an alternative embodiment are configurable. This configurability option is particularly useful if/when a particular link is expected to experience lossy or jittery conditions, because it enables a tenant to configure the link with link metric values appropriate to those expected link conditions in order to minimize or eliminate flapping of the link.
  • the MCN components as described herein are configured to share link state data globally across the core network by exchanging messages, thereby enabling a link state view of the network.
  • the routing of traffic through the core network includes use of a dynamic link state protocol routing system distributed among multiple Dolfins and, as such, can be thought of as‘distributed’ because each Dolfin makes its traffic routing decisions independent of every other Dolfin in the network.
  • this ‘distributed’ routing control can cause routing loops to occur in which a first Dolfin routes traffic to a second Dolfin, and the second Dolfin, which is independently routing its traffic, routes back to the first Dolfin the very traffic received from the first Dolfin.
  • the routing loop can prevent the subject traffic from ever reaching its destination.
  • Embodiments are configured to perform distributed real-time loop avoidance to prevent routing loops that disrupt tenant traffic, and therefore limit“activated” links to avoid routing loops.
  • embodiments include distributed algorithms that make activation decisions locally (node), based on a set of values referred to herein as ‘intermediate variables’ stored at each node.
  • intermediate variables stored at each node.
  • the loop avoidance algorithm is implemented separately for each traffic destination. Messages are then exchanged between direct neighboring nodes to negotiate updates to the variables.
  • the controlling of activation decisions locally in each node limits communication to communication between neighbor nodes, and is robust to Dolfin failure as it avoids a single point of failure.
  • Data routing at each Dolfin comprises two components, but is not so limited.
  • FIG. 36 is a block diagram showing Dolfin components involved in loop avoidance, under an embodiment.
  • the first component comprises the routing engine configured to generate a route between a source and an egress destination, as described in detail herein.
  • the second component includes a loop control component configured to perform loop avoidance analysis on generated routes. Therefore, upon generating routes, the routing engine sends the generated route to the local loop control component, which performs loop avoidance.
  • the routing engine sends the generated route to the loop control component prior to providing or pushing the generated route to the OVS but is not so limited.
  • the routing engine Upon receiving a message from the loop control component informing that the generated route avoids any loop, the routing engine pushes the generated route, comprising flow table entries, to the corresponding OVSs.
  • This loop avoidance scheme along with the high frequency measurement of link statistics, enables dynamic, high frequency rerouting of data and/or bandwidth allocation/reallocation, in contrast to relative infrequent rerouting used by conventional data routing equipment.
  • the loop control component of each Dolfin is configured to communicate with the loop control components in other Dolfins of the network in order to negotiate the node values as described herein.
  • the loop control component of each host Dolfin also communicates with the local routing engine of its Dolfin, because routing decisions of the routing engine are required to comply with the loop avoidance parameters described herein. Therefore, when an iteration (set of network updates) starts, the routing engine requests and receives a next hop set from the loop control component.
  • the next hop set comprises a list of neighboring nodes to which traffic routing is allowed for each destination.
  • the routing engine then executes the routing algorithm using the next hop set to control the list of neighboring nodes available for routing traffic.
  • the routing engine Upon generating the traffic routing decisions, the routing engine sends to the loop control component a list of next hop nodes actually being used by the routing engine for traffic routing.
  • the loop control component uses the list of next hop nodes actually in use to ensure that flowing traffic is not cut off as a result of operations involving calculation and control of the node value.
  • the loop control component is configured to superimpose on the fast-moving link state routing protocol a relatively slower moving distance vector technique that limits“activated” links in order to avoid routing loops.
  • the distance vector method is implemented using a loop avoidance algorithm that limits the activated loops.
  • the loop avoidance algorithm makes activation decisions locally, based on a set of node values referred to herein as“intermediate variables” generated and stored at each node.
  • Node values are negotiated between neighbor nodes using messages exchanged directly between the nodes. Further, each node is required to track information including its node value, the node values of its neighbors, its neighbors’ knowledge of its node value.
  • the loop avoidance algorithm is implemented separately for each traffic destination and begins by fixing the source and destination nodes for a route in the network, and assigning a node value to the nodes corresponding to the fixed nodes.
  • a single rule governs operations under the loop avoidance algorithm, and that rule states that a node can only send traffic to its neighbor node if the node value of the sending node is higher than the node value of that neighbor node. Loops are therefore avoided under this rule because an attempt by the neighbor node (lower node value) to“return” traffic to the originating node (higher node value) would violate the rule because the neighbor node would have to send (return) traffic to the originating node, which has a higher node value.
  • a node can decrease its own value, and so doing might require the node to cease routing traffic to one or more of its neighbors for which it now has a lower node value. Further, when a node changes its node value it is configured to communicate the new node value to its neighbor nodes. A node can also decide that it should increase its own node value. However, once the new higher node value is computed, and before actually changing its node value to the higher value, the node is configured to ensure that neighbor nodes having higher node values are aware of the new higher value and stop routing traffic to the node (since it currently has a lower node value). A series of handshake messages are used between the node needing to increase its node value and each of its neighbor nodes.
  • the handshake series is initiated by the node increasing its value, and includes a message to inform one or more neighbor nodes that its node value is going to be increased.
  • the handshake series also includes a confirmation from the neighbor node that it has updated the node value and stopped routing traffic to the subject node.
  • the subject node is configured to increase its node value only after receipt of the confirmation message from the neighbor node(s).
  • the node values are generally calculated to be the average cost to get from the source node to the destination node, with cost being determined according to the objective function(s) used in routing particular traffic between the source and destination nodes as described in detail herein.
  • Figure 37 is an example involving node value calculation in a portion of the core network, under an embodiment. The calculation and assignment of node values begins by assigning a node value or cost of zero to the destination node D. Using an example involving the HALO routing algorithm, a source node S has two available paths to the destination node D.
  • a first path involves a first link directly to an intermediate node I, and a final direct link between the intermediate node I and the destination node D, so the cost corresponding to the first path is computed as the sum of the cost of the first link (Ll) (determined from its objective function) and the cost of the intermediate node (Cl) (i.e., Ll+CI).
  • a second path involves a second link directly from the source node S to the destination node D, and the cost corresponding to this second path is the cost of the second link (L2) determined from its corresponding objective function.
  • the cost of the source node is therefore calculated as the sum of a first quantity that is the first path cost multiplied by the percentage of traffic routed via the first path (i.e., (Ll+CI)*(0.8)), and a second quantity that is the second path cost multiplied by the percentage of traffic routed via the second path (i.e., L2*(0.2)).
  • the loop avoidance algorithm is configured to assign a value to each node in the network.
  • Each node tracks knowledge about its own value and the values in its neighbor nodes.
  • An expression e.g., Vfx; y ⁇ z
  • Vfx; y ⁇ z is used to denote the value in x, as believed to be known by y, stored in z.
  • stores its own value (V(x; x
  • node values are initially infinity.
  • each node initiates an update process to update its value to the shortest path cost to the destination as described in detail herein.
  • Embodiments maintain invariants on the node values. For example, a first invariant (e.g., Vfx; x
  • a second variant e.g., Vfx; y,
  • a third variant represents that a node x can activate a link to neighbor y only if the value ofy is less than the value of x (as known by x: Vfx; x
  • a node updates its own value in accordance with a communication procedure configured to negotiate the change with neighbor nodes, while maintaining the invariants described herein. More specifically, when a node x decreases its value to Vo, x sets the variables Vfx; x
  • x) to Vo simultaneously, x sends a message to each of its neighbors announcing the decrease in x to Vo , and each neighbor y ; of x, upon receiving the message, sets V(x; y, ⁇ y,) Vo.
  • x Upon receiving acknowledgment from yo, x sets V(x; yo ⁇ x) to Vi, and updates its local value V(x; x
  • the locally computed shortest path cost is likely to change during each iteration for all nodes except the destination node.
  • a shortest path cost that stays the same is treated as a decrease, and handled as described in detail herein for decreasing a value.
  • nodey may choose how long to wait before acting on the increase and sending back an acknowledgement. Embodiments choose to always act immediately on the increase as such an approach realizes speed and simplicity. However, it could mean that node y is temporarily left without a route to the destination (due to the third invariant).
  • An alternative procedure allows node y the option of waiting to complete an increase to its own value before acknowledging to node x, in the case that node x is its only valid successor.
  • node y is configured to send back a“partial acknowledgement,” allowing node x to increase its value to just below the value of node y. The partial acknowledgement allows node x to make progress towards convergence, without temporarily disallowing the only viable route of node y.
  • Update messages include sequence numbers, and acknowledgments include the sequence number and value being acknowledged. In this manner out-of-order updates are ignored. Nodes maintain knowledge of their‘increase’ operations that are pending acknowledgment. A timer is used to periodically retransmit pending increase operations, in case of lost packets. A pending operation can be eventually discarded when a later increase operation is successfully acknowledged and processed, a later decrease operation occurs, and/or some timeout is reached.
  • Every node generates either an increase or a decrease at every iteration. If a node x does not receive any message from its neighbor nodey for some number of successive iterations, it assumes node >' to have gone down, and updates V(y; x
  • Embodiments set node values by computing average path cost to the destination using a recursive formula. Let c(s, t) denote the average path cost for traffic routed from node 5 to destination node t. If 5 has outgoing links hto neighboring nodes v each carrying a proportion r, of the traffic, then
  • node t is configured to send back a“partial acknowledgement,” allowing node 5 to increase its value to just below the value of node t.
  • acknowledgement allows node 5 to make progress towards convergence, without temporarily disallowing the only viable route of node t.
  • Dolfin When a Dolfin comes online, it is configured to send an initialization request to all neighboring Dolfins.
  • the neighboring Dolfins send back initialization responses, indicating their own node values and most recent knowledge of the value of the initiating node. This mechanism allows for smooth recovery from Dolfin failures; when the Dolfin (or replacement Dolfin) is brought back online, it can enter the network and recover its state from talking to its neighbors.
  • Watchdog, Dolfin, and OVS interact with each other to control routing of traffic via the MCN.
  • Watchdog is configured to boot and load information about its
  • embodiments include a coupling between the control packet (Watchdog) userspace daemon and the co-located Dolfin, which transmits measured RTT on each adjacent link. Inter-Dolfm communication transmits the RTT measurements to other Dolfins in the same MCN and in different MCNs. The information for all links in the network is then used (e.g., ONOS) in routing decisions. Watchdog flows are forwarded to the OVS, which is configured to connect the Watchdog container to the Orca and to fill link quality packets with OVS data (TX/RX packet info).
  • OVS OVS
  • Dolfin is configured to listen through a socket for Watchdog messages.
  • the messages include a LINK UP message to make a link active, and a LINK DOWN message to make a link inactive.
  • the messages also include a REGISTER WPP message, which is a registration message from which Dolfin learns MAC and IP addresses for the Watchdog container, sends parameter configuration to Watchdog (probe rates and timeouts), installs flow rules to allow incoming/outgoing traffic to the
  • Watchdog container port notifies Watchdog of all neighboring links, and installs flow rules to allow and forward packets to/from this Watchdog to neighbors.
  • the messages include an RTT MESSAGE with link qualities (e.g., latency, jitter, loss), and a REQUEST NEIGHBORS message by which Watchdog requests neighbor links.
  • Watchdog is configured to perform network monitoring, and to report monitored data or results as described herein.
  • Figure 38 is a flow diagram for monitoring parameters of the MCN, under an embodiment.
  • the network monitoring includes but is not limited to monitoring link status, and round-trip time (RTT) and latency, for example.
  • Watchdog comprises configurable parameters that allow setting a speed for probes to neighboring links (e.g., default speed is lOms).
  • Watchdog protocol periodically measures RTT on each link in the network by sending a time-stamped packet across the link and back. For each link, the latency value is calculated using the RTT value divided by two. Therefore, Watchdog is configured to measure latency and maintain latency states for each network link connected to the POP and running Watchdog, and provide the latency data to the Dolfins for the purpose of routing latency-sensitive traffic along the minimum latency path. Data of RTT and latency can be shared by sending OSPF or PWOSPF updates, and is also provided to web application for display via the web UI.
  • Each Watchdog as a component of the monitoring service of the MCN, is configured to obtain or measure data of the links throughout the network, and to provide the link data to its corresponding Dolfin for use in traffic routing operations.
  • the link data obtained for each link includes, but is not limited to, link state (e.g., up, down), packet loss rate, jitter, and latency (e.g., travel time, variance in travel time).
  • Watchdog is configured to measure link status (bidirectional forwarding detection (BFD)) and link qualities between POPs, and to determine that a link is down when it stops receiving detection packets (BFD) from a neighboring Watchdog over that link.
  • BFD bidirectional forwarding detection
  • Each Dolfin in the MCN includes multiple single-hop links to multiple other Dolfins however, for clarity, the example that follows describes a portion of the network including a single link connected between two Dolfins.
  • Figure 39 is a block diagram showing Dolfins and corresponding Watchdogs in an example portion of the core network, under an embodiment. More specifically, this example portion of the network includes a first Dolfin connected to a corresponding first OVS, and this first OVS includes a port that connects to a first end of a link in the underlay network as described herein. Similarly, a second Dolfin is connected to a corresponding second OVS, and this second OVS includes a port that connects to a second end of the link.
  • a first Watchdog is connected to each of the first Dolfin and the first OVS, and a second Watchdog is connected to each of the second Dolfin and the second OVS.
  • Each of the first Dolfin and the second Dolfin installs rules in its corresponding OVS that enable its corresponding Watchdog to exchange packets across its links. In this manner, the link is configured for use by each Watchdog to obtain link data of the other Watchdog via message exchanges over the link.
  • Dolfin uses messages (OSPF HELLO) to identify neighboring Dolfins, and then provides information of the neighboring Dolfins to Watchdog.
  • Watchdog receives the status information from its corresponding Dolfin, and this status information includes information of the links the Watchdog is to monitor or probe.
  • Watchdog probes/monitors neighbors as instructed by Dolfin, and updates link status based on detection packets (BFD) responses and timeouts. For each monitored link, the monitoring Watchdog continuously generates and sends probes or probe packets (e.g., bidirectional forwarding detection (BFD)) across the link, so that a receiving Watchdog on the other end of the link can determine a state of the link based on receipt of the probe packets.
  • BFD detection packets
  • Watchdog further determines latency of the link using time-stamped packets. In so doing, the Watchdog generates a time-stamped packet and transmits the packet across the link. LTpon receipt of this packet back at the transmitting Dolfin, the round-trip time (RTT) across the link is determined as the difference between the time of receipt and the time of the time stamp. The link latency is then determined from the RTT, and jitter is calculated as the variation of the latency.
  • RTT round-trip time
  • the Watchdog of an embodiment is configured to measure packet loss on each network link, and to provide the resulting data to its corresponding Dolfin.
  • a network link between two endpoints comprises a physical link
  • the link is a logical link such as a link on top of a data carrying protocol (e.g., Multiprotocol label switching (MPLS))
  • MPLS Multiprotocol label switching
  • MCN components of an embodiment are configured to measure packet loss on a link between two endpoints using probing packets and byte counters.
  • the interfaces on the first OVS and second OVS (corresponding to the first Watchdog and second Watchdog, respectively) track cumulative bytes/packets sent and received.
  • the probes are tagged with these values, and from their difference the cumulative bytes/packets lost in transmission are calculated or determined. By comparing two such cumulative values, the bytes/packets lost during the time between the two probes is calculated.
  • the OVS instances are configured to tag (e.g., continuously on a periodic basis) transmitted probing packets with byte counters, such that a transmitting OVS maintains a counter of a number of bytes transmitted by that OVS.
  • Each OVS is also configured to maintain a counter of a number of bytes received at that OVS, so the OVS on the end of the link opposite the transmitting OVS includes a count of the number of bytes received.
  • the information of the transmit counter provides a packet transmit rate
  • the information of the receive counter provides a receive rate
  • the packet loss rate is determined as the difference between the transmit and receive rates.
  • the Dolfin is configured to handle it as a link failure event, but is not so limited.
  • Dolfin retains the view of active links to neighbors, and sends OSPF update packets to them. Upon receipt, neighbors process this information and detect that Dolfin has active egress links and then they will also bring them up.
  • Dolfin uses messages (e.g., OSPF HELLO) only to discover or identify neighboring Dolfins.
  • Dolfin provides the information of neighboring Dolfins to its Watchdog, which only probes or monitors neighbors as directed by its Dolfin. Further, only Watchdog is configured to update link status based solely on detection packets (BFD) responses and timeouts.
  • BFD detection packets
  • Watchdog also includes a timeout as a component of connection monitoring with its Dolfin, and watchdog is configured to use the timeout to determine that Dolfin is down and stop packet exchange when Dolfin is down. If Watchdog loses connectivity with its Dolfin it means either that Dolfin is down, or that Dolfin is running without link status visibility, possibly leading to incorrect routing. Regardless, a loss of connectivity between Watchdog and Dolfin means information about link status cannot be provided to neighboring POPs.
  • Dolfin is down, the corresponding OVS is configured to run in failover mode using backup flow rules, as described herein. This means that existing traffic flows continue using the last defined paths, while new traffic flows use shortest path-computed paths.
  • Watchdog is configured to continue running so neighboring POPs continue to send traffic to the host POP. Because Dolfin is down, neighboring POPs will no longer be receiving OSPF messages from it, and the links between the failed Dolfin and its neighbors will go down after the OSPF expiration time. Watchdog will then stop running after this happens, to prevent neighbors from using the host POP.
  • the OVS is configured to use port information as a traffic flow identifier.
  • the OVS is the traffic-forwarding element, and in so doing is configured to take into account the UDP ports when forwarding traffic. Consequently, the OVS of embodiments keep flows together according to source application type (e.g., layer 4 UDP port information) in order to match flows from the same source/destination. This enables traffic flows to be separated into component flows, which facilitates the dynamic load balancing of an embodiment.
  • source application type e.g., layer 4 UDP port information
  • the OVS is further configured for traffic routing including splitting of traffic flows for outputting from multiple different ports in support of multi-path routing.
  • the OVS is configured to include flow rules that perform either round-robin routing, or routing controlled by group tables.
  • the round- robin routing includes evenly distributing the total traffic throughput among a number of different paths to the destination.
  • embodiments use a hash function to split traffic among multiple paths to a destination. More particularly, the OVS is configured with group tables that split or distribute outgoing traffic flows among multiple output ports (aggregator) based on the weight of total throughput between a source and a destination. Therefore, as an example, a 60/40 split of flows between two paths would route 60% of the throughput on a first path, and route the remaining 40% of the traffic flows over a second path. Continuing with this example, consider ten (10) traffic flows having total throughput of approximately 100 Mbps between a source and a destination. The use of group tables configured to route the flows using a 60/40 flow split results in routing flows including approximately 60 Mbps of total throughput over a first path, and routing the remaining approximately 40 Mbps over a second path.
  • the OVS is also configured to support high availability through the inclusion of backup flow rules.
  • the backup flow rules which are installed in the OVS by Dolfin, are designated for use in the event of Dolfin failure or an absence of the primary flow rules, but are not so limited.
  • the OVS includes a secure mode in which it shuts down if its corresponding Dolfin is not detected, and as part of the shutdown the OVS may delete its flow rules. Further, the flow rules of the OVS have an expiry time, meaning that the rules are not available due to expiration even though the corresponding Dolfin is available.
  • the backup flow rules of an embodiment do not expire through idle or hard timeouts, and they remain constantly present in the case of a Dolfin connection loss, so they are available for routing traffic in the absence of the primary flow rules.
  • the OVS switches to use of the backup flow rules for traffic routing in the event the corresponding Dolfin is not detected or the primary flow rules have expired.
  • the backup flow rules are configured to route traffic via the shortest path, but are not so limited.
  • Dolfin is configured to create or add backup flow rules, reactively. When OVS has a connection to a Dolfin, these backup flow rules should be ignored. However, the backup flow rules are used to route packets when the Dolfin is down.
  • the backup rules can be included in a backup flow table, but are not so limited. Through ONOS, embodiments create a new table that includes backup flow rules that route based on shortest path. These backup flow rules match on a destination IP address, and have an aggregator (link) output port corresponding to the shortest path determined by OSPF.
  • Embodiments include components configured for monitoring the health of MCN components and logging data of the monitoring.
  • the monitoring and logging are configured for monitoring the health of MCN components and logging data of the monitoring.
  • central monitoring comprise the Elastic Stack log management platform, which is configured for log analysis, business intelligence, and web analytics, in addition to monitoring.
  • Figure 40 is a block diagram of the central monitoring, under an embodiment.
  • the central monitoring includes Elasticsearch and Logstash running in a Virtual Private Cloud environment (e.g., Amazon, etc.), and Beats distributed among the POPs and MCN services. Additionally, the central monitoring includes but is not limited to Riemann and Pagerduty.
  • Elasticsearch includes a distributed search and analytics engine configured for log analytics, full-text search, and operational intelligence use cases. Beats comprises lightweight agents configured as data shippers, and these agents are configured to send data to Logstash.
  • Beats agents are deployed at management plane or middleware components (e.g., provisioner, Bouncer, WEB-APP, disruptor, Couchbase). Further, an embodiment includes two additional types of Beats agents, namely Filebeat for log files (e.g., dolfin logs, orca logs, Watchdog logs, OVS logs, syslogs, and latency logs), and Metricbeat for metrics (e.g., VM CPET, VM RAM, VM disk usage, container CPET, container RAM), but is not so limited.
  • Filebeat for log files e.g., dolfin logs, orca logs, Watchdog logs, OVS logs, syslogs, and latency logs
  • Metricbeat for metrics e.g., VM CPET, VM RAM, VM disk usage, container CPET, container RAM
  • Logstash is configured to ingest data from multiple sources simultaneously, process the data, and send the processed data to Elasticsearch and/or Riemann.
  • Logstash functions to process a data pipeline in a stateless manner, and an embodiment scales it horizontally so that each instance of Logstash is present in its own node.
  • Elasticsearch in an embodiment includes numerous plugins, and can be configured to provide near-real time analytics and monitoring using large volumes of data. More particularly, Elasticsearch includes Kibana, Curator, and Dashboard
  • Kibana is configured to enable visualization of Elasticsearch data and quick browsing and analysis of logs, thereby enabling a rich overview of any component and resource of the Elastic Stack.
  • the Curator is a tool configured to manage the
  • the Dashboard Generator is configured to generate dashboards (including visualizations and searches) from the provisioned networks.
  • Elasticsearch further includes some number of data nodes, master nodes, and tenant/coordinating nodes, but is not so limited.
  • the data nodes are configured to hold data and perform data-related operations such as search and aggregations.
  • the data nodes can be horizontally scaled if overloaded.
  • the master nodes are configured to be responsible for lightweight cluster-wide actions. An embodiment allocates dedicated master nodes that do not perform data operations, but are not so limited.
  • the tenant/coordinating nodes of Elasticsearch are configured to receive tenant requests and coordinate them among different data nodes, as these requests may involve data spread throughout multiple nodes of the cluster. While each Elasticsearch node is a coordinating node, an embodiment runs a coordinating-only node along with Kibana in order to load balance requests. The coordinating node processes incoming HTTP requests and redirects operations to other nodes in the cluster as needed.
  • Riemann is an event stream processor configured to filter, combine, and act on flows of events.
  • Riemann comprises a centralized alerting tool that single-handedly accounts for large distributed systems and, in an embodiment, is deployed as a single instance per monitoring cluster.
  • the action on event flows of an embodiment includes communicating with PagerDuty to generate alerts.
  • PagerDuty is configured as an alert management system, which receives notifications from Riemann and contacts the responsible team member according to pre-specified parameters.
  • the monitoring and logging includes health checks that are condition checks on system components.
  • the health checks are configured to provide notifications regarding whether a monitored component is functioning properly.
  • Health checking is related to monitoring because it is monitoring with focus on component health. Health checks increase visibility of the MCN components by exposing component failures and warnings to dashboards accessible by a tenant or network operator. Further, automatic health checks constantly monitor and handle possible component failures in order to improve availability and resiliency of the MCN by speeding up component repair or replacement.
  • Figure 41 is a flow diagram for system health checks, under an embodiment.
  • Monitored components generate health logs that are collected through the monitoring stack pipeline.
  • each component is configured to generate a health check log file (e.g., through white monitoring), and write the log file to storage.
  • the components configured to generate the log files include but are not limited to Dolfins, Orcas,
  • the generation of the log files by each component includes the gathering of metrics and logs necessary to decide about system health, and append the health status based on data from log file generation, and generate the health log.
  • Filebeat is configured to obtain the health logs from their corresponding storage, and send the health logs to Logstash.
  • Logstash is configured to ingest data from multiple sources simultaneously, process the date, and send the processed data to Elasticsearch.
  • Elasticsearch includes a distributed search and analytics engine configured for log analytics, full-text search, and operational intelligence use cases. Logstash also sends the processed stream of health events to Riemann.
  • Riemann is configured to process the events data and rapidly check for‘status: “error”‘, and generate and send component alerts to PagerDuty. Riemann is also configured to make requests to the provisioner to solve the issue. The provisioner is configured to take actions to fix unhealthy components based on events data and detailed error messages received from Riemann.
  • Embodiments include a dashboard generator configured to generate monitoring dashboards.
  • the monitoring dashboards are configured to present monitored data of MCN components but are not so limited.
  • the monitoring components of embodiments are based in the ELK (Elasticsearch, Logstash and Kibana) stack as described herein, and Kibana is configured to display Elasticsearch data, such as log aggregates and/or dashboards.
  • the dashboards include but are not limited to graphs configured to display general information and summaries about different components or aspects of the system. More particularly, the dashboards are configured to present data for use in identifying services/components that are near failure due to one or more of resource exhaustion and infrastructure issues, thereby enabling users to identify and react to problems before they actually occur. Further, the dashboards are configured to enable more efficient problem diagnosis when troubleshooting or debugging a system through presentation of MCN data in a manner leading to quick elimination of suspected causes by just checking the graphs for the given system.
  • the monitoring and storage of data or logs used in operation of the dashboards comprises component data or logs organized according to an environment of a set of environments, and the plane in which the component resides.
  • the MCN includes a fixed set of environments including, but not limited to a staging environment, demo environment, quality assurance (QA) environment, beta environment, and production environment.
  • the MCN includes the management plane and the data plane.
  • Components of the management plane include the Bouncer, provisioner, WEB-APP, and WEB-UI, while components of the data plane include Orca, Dolfin, Watchdog, and OVS.
  • Components of the MCN also include the underlay network and the overlay network, as described in detail herein.
  • the underlay network components include but are not limited to a set of VMs within an environment, where embodiments include multiple VMs in the same location of an underlay (due to high availability features), and each VM includes multiple Orcas, Dolfins and Watchdogs along with a single OVS deployment.
  • the overlay network includes a tenant deployment (tenant) within an underlay, and each overlay includes one each Orca, Dolfin and Watchdog deployment.
  • FIG 42 shows an example involving selection of a dashboard using a hierarchy of dashboards, under an embodiment.
  • Dashboard selection in this example comprises a flow in which a list of environments is presented (e.g., QA, staging, beta, production, demo) for selection.
  • a list of environments e.g., QA, staging, beta, production, demo
  • a list of planes corresponding to the environment is presented (e.g., management, data, underlay network (e.g.,“Ericsson”,“Azure”)) for selection.
  • a plane e.g., Management
  • a list of components e.g., Bouncer, provisioner, WEB-APP
  • dashboards or graphs are presented (e.g., All components CPU stats, All components RAM stats, All components Disk stats, All components Network stats) corresponding to all management plane components.
  • dashboards or graphs are presented (e.g., CPU, RAM, Disk, Network, Logs, Log Stats) corresponding to the selected component.
  • FIG 43 shows an example involving selection of another dashboard using the hierarchy of dashboards, under an embodiment.
  • dashboard selection in this example comprises a flow in which a list of environments is presented (e.g., QA, staging, beta, production, demo) for selection.
  • a list of planes corresponding to the environment is presented (e.g., management, data, underlay network (e.g.,“Ericsson”,“Azure”)) for selection.
  • underlay network provider e.g., Ericsson
  • Underlay networks e.g., Underlay 1
  • a list of VMs is presented (e.g., VM 1, VM 2) corresponding to the selected underlay network.
  • numerous dashboards or graphs are presented (e.g., All VMs CPU stats, All VMs RAM stats, All VMs Disk stats, All VMs Network stats)
  • a list of tenant bridges is presented (e.g., weO, wel) corresponding to the selected VM.
  • numerous dashboards or graphs are presented for selection (e.g., CPU stats, RAM, Disk, Network) corresponding to the selected VM.
  • a list of dashboards or graphs e.g., Ping, Health, OVS, Auth, Syslog is also presented relating to other health parameters of the selected VM.
  • a list of components is presented (e.g., Dolfin, Orca, Watchdog) corresponding to the selected tenant bridge.
  • numerous dashboards or graphs are presented for selection (e.g., All components CPU stats, All components RAM stats, All components Disk stats, All components Network stats) corresponding to the selected tenant bridge.
  • dashboards or graphs are presented (e.g., CPU, RAM, Disk, Network, Logs, Log Stats) corresponding to the selected component.
  • FIG 44 is a flow diagram for updating dashboards, under an embodiment.
  • the Kibana dashboards comprise one or more agents running within the same VM as Elasticsearch and Kibana, but are not so limited.
  • the dashboards include the templates from all searches, visualizations and dashboards.
  • the dashboards periodically receive or fetch new information stored in Elasticsearch, such as new hosts and new underlays. The new information is received or fetched hierarchically (receive information of
  • the dashboards apply the new information from Elasticsearch into templates to generate new searches, visualizations and dashboards (documents). The dashboards then upload the new set of documents to Kibana.
  • Health monitoring of MCN components further includes passive monitoring.
  • the MCN components of embodiments are configured to include passive measurement (e.g., TCP connections) of data flow rates across last mile connections, and outside of the controlled overlay network, in order to identify data loss across these last mile connections.
  • the passive monitoring or measurement of network performance comprises use of a set of simultaneous equations but is not so limited. This passive measurement includes the tracking of data flow rates across all routes of the MCN to determine fluctuations in data rates resulting from loss. In so doing, components measure across the entire MCN the data flow rate statistics of all routes between their source and destination endpoints, and evaluate the data flow rate statistics using a system of simultaneous equations.
  • embodiments analyze the flow rate statistics using a system of simultaneous equations in order to passively identify last mile connections related to or responsible for the data loss.
  • the continuous evaluation during network operations of the flow rate data using the simultaneous equations enables identification of last mile connections potentially responsible for any detected collapse in throughput or anomalous data losses.
  • an embodiment Upon identification of a last mile connection that is the likely source of data loss, an embodiment is configured to“move” that last mile connection from a current port to a different output port on its corresponding POP in an attempt to route the traffic using a different last mile connection.
  • Figure 48 is a flow diagram showing, under an embodiment. This example involves a first data flow Dl through the MCN between a first tenant site Sl and a second site S2, and a second data flow D2 through the MCN between a third site S3 and a fourth site S4.
  • the second tenant site S2 and fourth tenant site S4 share a common POP (e.g., POP 3). It is determined that the flow rates of both data flows D1/D2 are experiencing data loss, and it is further determined that the loss is not occurring within the MCN. Therefore, it is assumed that the data loss is occurring in one of the last mile connections, but the MCN is not able to access specific data of each last mile connection in order to determine which one might be causing the data loss.
  • POP e.g., POP 3
  • an embodiment can“move” the last mile connections on the POP to a different output port of the POP in an attempt to route the traffic using a different last mile connection.
  • embodiments include multiple alternative methods for controlling last mile connections in the face of data loss suspected over those connections.
  • One alternative method includes DNS-based redirection to redirect traffic from a current POP to a different POP, and the change in POP causes a change in last mile connections.
  • Another alternative method involves a CPE-based solution that instructs the CPE to use an alternative route for the last mile connection to the corresponding POP.
  • the term“high availability” as used herein includes maintaining availability and functionality of the MCN and preventing an interruption in service in the event of a failure of one or more components of the MCN.
  • the management plane components comprise the WEB-APP, Bouncer, and provisioner, as described in detail herein.
  • Figure 45 is a block diagram of the management plane, under an embodiment.
  • Each of the web app, Bouncer, and provisioner is coupled or connected to a corresponding load balancer and data store.
  • an auto-scaling component is coupled to each of these components.
  • the auto-scaling component of an embodiment is configured to maintain a pre-specified number (e.g., two, three, etc.) of instances of its corresponding component.
  • the description herein includes embodiments having two instances of each component, but the embodiments are not limited to two instances and can have any number of instances as appropriate to a configuration of the MCN.
  • the load balancer of each component is configured to balance the load between the multiple instances of each component.
  • Each load balancer uses a round-robin process for balancing requests (e.g., TCP request) from its corresponding component, but embodiments are not so limited.
  • TCP request e.g., TCP request
  • embodiments When deploying a new version of a component in a high-availability network configuration that includes at least two instances of each component, embodiments generate two new instances of the component, and connect these new instances to the load balancer.
  • the load balancer is configured to route new connections to the new instances, and to drain existing connections to the previously used set of components or let them expire as described herein. The connections to the previously used set of components are disabled subsequent to the corresponding drain count being zero, meaning no connections are being handled by the components.
  • the MCN includes a logical division of workspaces or“environments” each operating its own MCN.
  • the environments include but are not limited to development, quality assurance, alpha, beta, staging, and production environments, and high
  • the environments are maintained in logically separate or isolated regions of a cloud service of the web services cloud in a given geographical region (e.g., Europe North 1, ETS West 3, etc.), and but are not so limited.
  • Each environment includes a corresponding management plane, and therefore includes multiple instances of each of the management plane components.
  • Embodiments include failover instances of each of the environments, and the failover instances are located in a different geographical region of the cloud service than the primary instances (e.g., primary instance hosted in US West 3 cloud server, failover instance hosted in Europe North 1 cloud server).
  • the data stores of the primary environment are synchronized to data stores in the failover environment. In the event the primary version of an environment goes down, the DNS handles the switchover from the primary environment to the failover environment, and the synchronized data stores eliminate or at least minimize any data loss during the failover process.
  • High availability of the management plane further includes operating multiple instances of monitoring and logging components (e.g., Elastic, Logstash, Kibana,
  • the MCN control plane components include Orca, Dolfin, Watchdog, and aggregator as described in detail herein, and high availability of the control plane generally comprises the use of multiple containers.
  • High availability of the control plane includes preventing Dolfin failures from causing interruption of service, where Dolfin failures include Dolfin restart due to software crash, Dolfin full restart due to software crash with data loss, and Dolfin overload.
  • High availability additionally includes enabling Dolfins to automatically recover from failures, and enabling upgrading of Dolfin versions without interruption of service.
  • Dolfin is configured to read existing rules from the OVS and match their selectors to the corresponding traffic classes. Dolfin is configured to use that existing information to organize its ephemeral traffic class table tree and incorporate those rules into the ONOS flow and group store.
  • the claiming of existing flow rules avoids having to erase and completely rebuild all rules, as rules are expected to be claimed according to the existing routing data (routes, traffic classes, network configuration), and those that are not a perfect match are erased as not claimable.
  • While embodiments are configured to retain or claim some of the existing flow rules, the claiming of existing rules across Dolfin instances does not enable the Dolfins to control new traffic flows not accounted for in the existing rules.
  • a pre-specified rule e.g., SEND TO CONTROLLER rule
  • High availability of the control plane therefore includes the use of backup rules as described herein.
  • the backup flow rules which are installed in the OVS by Dolfin, are designated for use in the event of Dolfin failure or an absence of the primary flow rules, but are not so limited. When OVS has a connection to its Dolfin, the backup flow rules are ignored. However, the backup flow rules are used to route packets when the Dolfin is down. The backup flow rules are configured to prevent interruption of service until the corresponding Dolfin returns to service. In order to use the backup flow rules, embodiments include alternative processes for handling unmatched packets.
  • an embodiment in response to losing a connection to its Dolfin, includes a modified OVS that is configured to not send new flows to the pre-specified rule for new flows (e.g., SEND TO CONTROLLER).
  • a modified OVS that is configured to not send new flows to the pre-specified rule for new flows (e.g., SEND TO CONTROLLER).
  • unmatched flows instead of sending unmatched flows to the Dolfin where they are dropped (as the Dolfin is not operational), unmatched flows are routed according to pre-computed static shortest path metrics (e.g., latency). Therefore, for example, when new traffic arrives from a tenant and primary flow rules for this new traffic are not yet installed in the OVS, the new traffic is routed using the backup rules until such time as the primary flow rules are available.
  • embodiments include a modified OVS that is configured to send new flows both to the pre-specified rule for new flows, and to a set of alternative or fallback flow rules.
  • new flows would not hit the Dolfin, thereby avoiding any routing delay and/or packet drops.
  • Maintaining high availability of the control plane also includes the use of health checks that include condition checks on control plane components, as described in detail herein.
  • the health checks are configured to provide notifications regarding whether a monitored component is functioning properly, thereby exposing component failures and warnings in advance of a failure.
  • the health checks are configured for external queries. If a health check indicates a component is in poor or failing health, then the component can be“repaired” or restarted. Further, embodiments are configured to create a new container instance that is hot-swapped with the component exhibiting poor/failing health.
  • Components having operations that impact the data plane include but are not limited to Dolfins, Orcas, OVSs, Watchdogs, servers, underlay network, traffic managers, and the last mile connections.
  • the Dolfins are configured to handle rule installations for new connections and, while failure of a Dolfin does not affect existing traffic flows, it results in new connections not being forwarded, as described herein.
  • the Orcas are configured to install SNAT/DNAT rules for end-to-end connections, and receive health check responses from the traffic manager (or DNS Health Check). Failure of an Orca, while not affecting existing traffic flows, results in failure of the health check response, and prevents new connections from being able to reach the corresponding POP.
  • the OVSs are configured to forward packets, so OVS failure results in failure of packet forwarding.
  • the Watchdogs are configured to perform probing (e.g., latency, jitter, packet loss, etc.) and bidirectional forwarding detection (BFD), and failure of a Watchdog renders the corresponding Dolfin unable to forward traffic to neighbors.
  • the POPs are configured to host the containers and forward packets, and failure of a POP causes packets to not be received/forwarded by the POP.
  • the underlay network or link functions to provide interconnectivity between POPs, and failure of the underlay network means packets cannot be forwarded through the link.
  • the traffic manager functions to return the latency -based DNS entry (return the IP of the nearest available POP to the tenant), and failure causes the tenant to not be able to reach the POP.
  • the last mile functions as the connection between the tenant and the POP (ingress), and between the POP (egress) and the egress destination. If last mile between tenant and ingress POP fails, there is a high likelihood the tenant Internet connection is down. If last mile between egress POP and egress destination fails, components of the MCN reconfigure the route to use other egress points.
  • FIG. 46 is a block diagram showing a high availability configuration involving replicated tenant stacks at a POP, under an embodiment.
  • This configuration involves a first stack (e.g., orca, Dolfin, OVS) and a second stack (e.g., orca, Dolfin, OVS) corresponding to and supporting a tenant.
  • first stack e.g., orca, Dolfin, OVS
  • second stack e.g., orca, Dolfin, OVS
  • Health check periodically (e.g., 10 seconds, etc.) checks the health of the stack components, and provides the metrics used by components to redirect traffic to another active tenant stack when conditions warrant.
  • Figure 47 is a block diagram showing an example high availability configuration involving the data plane of a portion of the MCN, under an embodiment. Redundant VM instances at each POP run in active-active mode to provide high availability for the data plane.
  • This example embodiment includes redundant VM instances VM1-P, VM1-B at a first POP Pl, redundant VM instances VM2-P, VM2-B at a second POP P2, and redundant VM instances VM3-P, VM3-B at a third POP P3, but are not so limited.
  • the primary and backup VM instances do not share the same underlay network, but are not so limited. Between any two locations on the MCN, the
  • each Dolfin maintains a complete bipartite graph of the primary /backup pairs for communication of control messages to neighboring POPs.
  • the DNS service responsible for attracting traffic to the MCN checks the health status of all VM instances, and any detected failure of a primary VM instance results in a fast failover to the backup VM instance. While the terms“primary” and’’backup” are used herein to distinguish between two VMs at the same location, both VMs function as primary VMs in active-active mode.
  • embodiments include pre- installed backup flow rules in each OVS, as described herein.
  • the backup flow rules are configured with traffic forwarding instructions in the event a control plane component fails as described in detail herein. Generally, upon failure of a control plane component, traffic is forwarded through the data path defined by the backup rules until the control plane is recovered.
  • the primary /backup pair at each POP is in active-active mode.
  • the DNS Traffic Manager
  • the DNS Traffic Manager
  • checks the health of every primary and backup e.g., checks health of each POP every 10 seconds, each tenant caches DNS with TTL every 30 seconds.
  • the primary ingress POP Pl is down
  • the secondary ingress POP P2 DNS
  • the primary egress POP P3 is down
  • the secondary egress POP P2 is used.
  • OVS backup rules are used.
  • OVS/VM is down, other POPs are used.
  • the active-active mode comprises, at each POP, two VMs that are both active (e.g., ready to forward traffic).
  • the two VMs are not collocated, but embodiments are not so limited.
  • Each VM comprises all running data plane components (Dolfin, Orca, OVS, Watchdog) such that, between two locations, the pairs of (primary, backup) create a complete bipartite graph through the Dolfin bridges.
  • Dolfin knows its neighbor primary /backup, and communicates (e.g., OSPF/probing protocol packets) between both of them.
  • the topology includes all primaries and all interfaces.
  • Embodiments provide high availability of the data plane and also the control plane by configuring MCN components to address failures in the path from tenant to egress destination, including primary ingress POP, intermediary POP, and primary egress POP.
  • MCN components to address failures in the path from tenant to egress destination, including primary ingress POP, intermediary POP, and primary egress POP.
  • a detailed description follows of failure points within each of the primary ingress POP, intermediary POP, and primary egress POP, and configurations for providing high availability at the failure points.
  • embodiments handle failure of the primary Dolfin, as well as the backup Dolfin, by using OVS backup flow rules to forward traffic to the corresponding Orca. Failure of the primary ORCA results in failure of the DNS health check to the primary, in which case the DNS returns the backup IP, and the secondary Orca is used. When the backup Orca is down, the DNS health check fails for the POP and returns the IP of the next closest available POP.
  • Dolfin In response to failure of the primary Watchdog, Dolfin sends traffic via the Internet. Additionally, in response to failure of the backup Watchdog, Dolfin also sends traffic to the Internet.
  • Failure of the primary OVS is indicated by failure of the DNS health check (due to Orca bridge failure), in which case the DNS returns the backup IP, and the secondary Orca is used. Failure of the backup OVS is also indicated by failure of the DNS health check (due to Orca bridge failure), in which case the DNS returns the IP of the next closest available POP.
  • Dolfin is configured to use other available links. When all primary outgoing links are down, Dolfin is configured to send traffic out over the Internet.
  • Orca detects that all primary links are down, and stops responding to DNS, causing the backup to be utilized.
  • Dolfin When an outgoing link of the backup fails, Dolfin is configured to use other available links. When all backup outgoing links are down, Dolfin is configured to send traffic out over the Internet.
  • embodiments handle failure of the Dolfin using OVS backup rules to forward traffic to the Dolfin at the next POP (next hop) in the route. Failure of Orca does not affect operations.
  • the intermediary POP is unreachable and will not be used by the neighbor POPs.
  • embodiments handle failure of the primary Dolfin, as well as the backup Dolfin, by using OVS backup rules to forward traffic to Orca. Failure of both primary and backup Orca controllers does not affect operations.
  • the secondary egress POP is used by neighboring POPs (selecting egress POP logic) when any of the backup OVS kernel module, VM, and Watchdog is unavailable or down.
  • An alternative embodiment achieves high availability of the data plane with two VMs at each POP.
  • a first VM is configured as active, and the second VM is configured as standby.
  • the standby VM is isolated from other neighbors, i.e. does not send/receive OSPF and WPP packets, and is idle except that it replicates traffic classes, routes and gateway configurations.
  • the provisioner is configured to maintain a database for primaries and backups. Upon detecting that the active VM is no longer available, the provisioner re-configures the standby VM, and the traffic manager (or any DNS services) is updated to point to the standby VM. Previous VXLAN tunnels are deleted, and VXLAN tunnels are created between the standby VM and neighbor POPs. The standby (now active) VM is reconfigured to push statistics to the WEB-APP, and the provisioner database is updated. When the original VM is subsequently revived it is reconfigured as the standby VM. Last Mile High Availability
  • tenant traffic is generally attracted to one of the edge POPs of the MCN as the ingress POP, transmitted through the MCN to an egress POP, and forwarded to an egress destination or endpoint from the egress POP.
  • Traffic of a tenant is directed to the MCN by providing a latency -based DNS entry to the tenant.
  • the control plane of the MCN decides the routes for packets forwarded between the ingress and egress POPs. Failures inside the MCN between the ingress POP and egress POP are detected and handled by the control plane, as described in detail herein. While the MCN is required to perform reliably at any time, it is equivalently important to achieve the high availability for the last mile connectivity. Following is a description of failure scenarios for the last mile between end-users and edge POPs, along with methods for detecting and recovering from the failures.
  • the ingress POP for a given tenant is determined using latency-based routing of the associated DNS service.
  • the DNS service includes a health check feature in the process resource record set selection, and the health check feature continuously sends health check messages to the endpoints specified for the resource record sets.
  • the health check messages are sent at pre- specified intervals but are not so limited. These health check messages are used to achieve high availability using the DNS redirections, because MCN components are configured to associate the resource record sets with health checks to redirect traffic from failed/failing POPs to healthy POPs.
  • the health check messages are continuously sent to the specified endpoints, and the health status is determined from the health check messages based on string matching.
  • the endpoint monitors the health status at each POP locally and provides corresponding replies to the health check messages.
  • the POP public IP with the least latency to the resolver is selected first.
  • the DNS checks the current status of the health check associated with that selected POP, and if the POP status is not healthy, the POP with the next best (lowest) latency is selected.
  • Embodiments of the MCN also include failure detection, including failure detection of POPs, connectivity between an ingress POP and tenant, and connectivity between an egress POP and server. Regarding failure detection of a POP, status of POPs is monitored locally. Additionally, embodiments collect interface statistics of the POPs. The health status of the POP is determined using these measurements.
  • Embodiments use active measurements between the end-user web pages and their corresponding POP for link performance monitoring.
  • the measurements include use of a JavaScript beacon injected into the response by MCN components during the
  • the beacon instructs the tenant to continuously fetch a URL which is associated with the ingress POP or a set of candidate POPs. Consequently, the tenant continuously checks the connectivity between itself and each POP, and reports the results to the web application.
  • the beacon of an embodiment is also configured to measure the latency and goodput to the POPs by downloading the resources pointed to by the URL, which can be used in performance- aware mapping between tenant and POPs.
  • embodiments detect failure of connectivity between an egress POP and service application using a web page that is available at the server. If the web page is not supported at the server, then the connectivity between the egress POP and the server is actively monitored by periodically sending probing packets to the server periodically.
  • the MCN When a failure of a primary ingress POP is detected, the MCN is configured to select a secondary ingress POP as described in detail herein. The traffic incoming from tenants corresponding to the failed primary POP is then redirected to the secondary ingress POPs.
  • the secondary ingress POP is selected according to latency measurements as described herein, but is not so limited.
  • Connectivity failure between the tenant and the ingress POP is determined when a tenant fails to connect to an assigned ingress POP.
  • Embodiments either disable the POP for the particular tenant, or temporarily avoid using the POP for all tenants and applications.
  • the failure of a primary egress POP can be recovered by changing the routing decision of the MCN, so the control plane in the core networks is therefore notified of this failure and traffic is rerouted to a secondary egress POP.
  • the Dolfins are configured to communicate to select a secondary egress POP for any application involved, and the Orcas are notified of the change by the secondary egress POP.
  • Soft failures represent situations in which each component of the MCN is operating properly but the current performance is below the expectation, for example, some metrics in the service-level agreement are not satisfied or the bandwidth of the Internet (last mile) is not sufficient.
  • the MCN of an embodiment monitors the performance in real time and adapts to new routes for performance improvement. The high availability of the last mile can be broken down into monitoring and route control.
  • embodiments include control of the end user that makes it possible to monitor the status of end-to-end connectivity as well as the performance of the connections in real time in the end user.
  • the performance metrics considered include latency, jitter, loss and throughput, but are not so limited.
  • Embodiments include two methods of end-user monitoring, web-based active measurement, and agent-based active measurement.
  • the web-based active measurement method for monitoring the connectivity status assumes that a web page is provided at the tenant for login in order to use the MCN, as described in detail herein.
  • an embodiment injects a JavaScript beacon into the response.
  • the beacon instructs the tenant to fetch a set of URLs that are associated with candidate POPs, perform a health check of the POPs, and monitor the connectivity status of the last mile.
  • the beacon also measures the latency and goodput to the POPs by downloading the resources pointed to by the URLs.
  • the beacon approach therefore enables measurement of not only the performance of the existing path, but also all alternate paths not being used by current connections, so that the optimal path for recovery can be quickly determined in the event the current path encounters failure or performance degradation.
  • Web-based monitoring may not be applicable for route control because the web- based server is not able to manipulate the operating system.
  • embodiments implement a MCN DNS server that handles the DNS request from the end user.
  • the DNS request contains only the DNS local resolver IP, so the MCN DNS server is configured to maintain a mapping between the DNS resolver and the end user ahead of the DNS request. This enables coarse- grained route control because all end users using the same DNS local resolver and aiming at the same egress destination will be controlled identically.
  • Agent-based active measurement comprises deployment of an agent in the end user. When using the deployed agent, the monitoring mechanism for agent-based active measurement is similar to the web-based active measurement method.
  • the routing control component of the last mile high availability comprises an agent deployed in the tenant device.
  • the agent is configured to control the route by modifying the DNS entry in the host file of the end user so that the new DNS entry is applicable when the existing connection fails and expires, or when there is new connection to be established.
  • Alternative embodiments of the MCN include consumer premises equipment (CPE) installed at the tenant site.
  • CPE consumer premises equipment
  • the CPE is configured to provide control of the routes by modifying the next hop of specific flows in the routing table. This enables real time changes to the route and for arbitrary traffic, not bounded by DNS cache timeout and not limited to only new connections. In particular, the traffic of current connections can be detoured to a better path, instead of suffering from the worse performance or
  • An external route is a publicly routable IP address configured by the tenant as one of the intended targets for traffic routed via the MCN.
  • Traffic received at the MCN and addressed to the intended target IP address is routed via the MCN to the egress POP “closest” to the target address.
  • the traffic is then routed from the egress POP to the target address over the Internet.
  • Embodiments provide high availability for egress failover by configuring all POPs as egress POPs.
  • Tenants configure their external routes (via the web UI and web application) by providing the domain name of the service they intend to access through the MCN, and the MCN components determine the best egress POP corresponding to the service.
  • the MCN middleware e.g., provisioner
  • receives the domain name and in response creates an alternative domain name (e.g., CNAME) that redirects to the MCN, as described in detail herein.
  • CNAME e.g., CNAME
  • the egress POP in turn routes the traffic to the intended egress destination via the Internet.
  • All POPs in an embodiment are configured to act as ingress POPs for a route.
  • embodiments provide high availability of external routes and thus avoid creating a single point of failure by configuring all POPs as egress POPs.
  • Configuring all POPs as egress POPs enables any POP of the MCN to function as an available route to the Internet and, thus, a route to any publicly accessible service.
  • every POP of the MCN is configurable as an egress point to any route, and the POPs are controlled across all nodes on the network so they all route to the same egress POP while it is designated as the egress POP for an Internet route to an egress destination.
  • Figure 49 is a flow diagram showing egress routes when all POPs of the MCN are configured as egress POPs, under an embodiment.
  • POP A is configured as the ingress POP for user A
  • POP B is configured as the ingress POP for user B
  • POP C is configured as the egress POP for the egress destination because it has the lowest cost relative to the egress destination, as described herein.
  • Egress route 1 is the last mile coupling between the egress POP POP C and the egress destination.
  • the traffic of user A is routed from user A to the egress destination via POP A, POP C, and egress route 1.
  • POP C goes down or otherwise becomes unavailable
  • the POP with the next lowest cost relative to the egress destination is configured as the egress POP for routing traffic to the egress destination.
  • the MCN determines that POP B has the lowest cost relative to the egress destination, and configures POP B as the new egress POP.
  • the MCN is configured to then reroute traffic of user A to the egress destination via POP A, POP B, and egress route 3.
  • the traffic of user B is routed from user B to the egress destination via POP B, POP C, and egress route 1.
  • POP C goes down or otherwise becomes unavailable
  • the POP with the next lowest cost relative to the egress destination is configured as the egress POP for routing traffic to the egress destination.
  • the MCN determines that POP A has the lowest cost relative to the egress destination, and configures POP A as the new egress POP.
  • the MCN is configured to then reroute traffic of user B to the egress destination via POP B, POP A, and egress route 2.
  • the Dolfins receive a list of egress POPs for a route, instead of receiving a single POP.
  • Dolfins of an embodiment are configured to receive an ordered list of POPs to use as egress for a route. When a new packet for a route is received, the receiving Dolfin evaluates or traverses the list of egress POPs to identify the first reachable POP in the list.
  • a Dolfin is configured to react when it detects a change in a POP status (e.g., active, down, etc.) in order to modify its flow rules in the event the change in POP status has any effects on routes corresponding to its traffic.
  • the list of egress POPs is ordered based on geographical location.
  • the provisioner database of an embodiment includes geo-positioning information, and the list of egress POPs is generated or determined based on the distance to the POPs as determined using the positioning information.
  • the provisioner is configured to provide the Dolfins with information of the list so that all Dolfins comprise the same order of egress POPs for a route.
  • Each POP is generally configured to use one public IP address per each tenant application supported by the POP as described herein.
  • Components of the MCN are configured to track the public IP addresses allocated to the MCN by a cloud service provider (e.g., Azure, Ericsson, etc.), and to map the IP addresses to specific routes.
  • a cloud service provider e.g., Azure, Ericsson, etc.
  • the MCN components are configured to perform the corresponding changes on the networking stack of the host service provider to forward tenant traffic to the Orca that corresponds to the tenant.
  • the components involved in managing the public IP addresses include the provisioner database, as well as the provisioner and Orca, but are not so limited.
  • the provisioner database is configured to include a table to track public IP addresses as they are provided by a cloud service provider, and track their usage as public IP addresses for routes. This comprises the provisioner database being configured to include two tables to track the public IP addresses as they are dynamically received for the POPs. These tables include an IP address data table (public ips table) that includes data of the IP addresses, and an IP address-mapping table (route public ips).
  • the IP address data table includes the IP address string and the corresponding host identification string that specifies the specific host corresponding to the IP address.
  • the IP address-mapping table which is used to create a mapping between a route and IP address, includes a route identification data string, and an IP address string. This table can be used by an API, to get a list of all the public IP addresses currently claimed for a certain route on a network.
  • the route identification data is not unique because a route can be associated with multiple IP addresses, but is not so limited. Once a route claims the public IP addresses required on all the POPs of the route, it then adds the addresses to this table.
  • the provisioner is configured to include an API that enables updating of the IP address list as more public IP addresses are received. This API configures the
  • provisioner to read the list of public IP addresses (which can be filtered based on POP, network, etc.) from the IP address mapping table.
  • Orca is configured to use these APIs to poll accordingly for public IP addresses.
  • the API is configured to automatically update the public IP tables.
  • the provisioner is further configured to modify the existing routes functionality to select public IP addresses accordingly and claim them for routes.
  • This modifying of the existing routes functionality to select public IP addresses comprises determining if all the nodes on the underlay network have at least one claimable public IP address and, if so, claiming one public IP address on each node for the route and creating the route mapping.
  • Each Orca is configured to ensure that packets intended for a specific egress destination address are correctly forwarded to the Orca that corresponds to that address and, in so doing comprises appropriate forwarding rules, address resolution protocol (ARP) entries, and iptables entries to allow packets coming into POPs of the MCN to be forwarded to the corresponding orca.
  • the forwarding rules are hosted at another MCN component or agent instead of Orca.
  • Embodiments use the existing polling framework to poll for the specific public IP addresses of this network/POP. Based on the public IP addresses currently being tracked, a“diff’ mechanism is used to detect deletions or additions. Each polling iteration is performed using a filter including network identification and host identification, so that each Orca only receives a list of the public IP addresses for which it is responsible.
  • Orca is configured to add an‘iproute’ entry forwarding packets destined to this new IP address to the corresponding Orca.
  • Orca is further configured to add an ‘iptables’ entry enabling packets destined to the new IP address to be forwarded to the corresponding Orca.
  • Orca is configured to add a proxy ARP entry for the new IP address.
  • Orca also periodically checks currently existing routes/iptable entries/proxy ARPs as a backup measure to ensure the routing table and host networking state are consistent with what is expected given the entries currently being tracked. Consequently, Orca is configured to periodically (e.g., every x seconds) determine that the routing table, iptables, and ARP entries exist for each known public IP address that is mapped to its corresponding tenant, and to add any information found to be missing.
  • Embodiments include a development pipeline for developing and fielding the software of the MCN.
  • the development pipeline comprises a sequence of environments including one or more of development, quality assurance, alpha, beta, staging, and production environments, as described herein.
  • the development of the MCN software flows through this sequence of environments prior to being fielded as a software-defined core network.
  • the software development also includes a variety of types of tests applied to the software, including one or more of functional testing, system/solutions testing, stress testing, performance testing, usability testing, acceptance testing, regression testing, and beta testing.
  • GUI for tenants to evaluate and deploy the infrastructure of the MCN.
  • embodiments include a sandbox component configured to simulate a copy of a network by creating network components and interconnecting them to form a large-scale simulated or virtual network.
  • the sandbox of an embodiment is based on Mininet, which is used to simulate a network by creating network components and interconnecting them to form a large-scale simulated or virtual network, but is not so limited.
  • the sandbox component is configured to enable a user to construct a network from scratch using the tools provided in the GUI.
  • the sandbox GUI is configured for users to add one or more cities that are close to their offices. Each added city comes with one default office, and the GUI enable users to also specify the number of offices attached to the city.
  • the sandbox GUI is configured to enable a user to then add links between the added cities.
  • the cities and the links can also be deleted.
  • a user can change the label of the selected element using a pop- up editor.
  • a link is selected in the GUI, the user can change the capacity of that link.
  • the GUI is configured to enable the user to select source and destination pairs to simulate the network, and send traffic using the selected source and destination pairs to test the network throughput.
  • the traffic in these simulations is routed via the MCN using the routing algorithms described herein, but is not so limited.
  • a component of the GUI is configured to display the dynamic throughput of all destination offices, and the maximum throughput is recorded for comparison.
  • control plane and management plane entities that control the MCN include running and testing the components of these planes on top of a portion of a live network of a corresponding tenant. Therefore, the GUI is configured to enable a user to evaluate MCN components (software) using at least a portion of a live network.
  • embodiments use an integration test suite for integration testing of the control plane and management plane entities in a portion of a live network.
  • embodiments implement a small-scale version of an actual network on in-house servers, and use this implementation for scale and performance testing.
  • Statistics of the live network operations reported by the control plane and management plane are monitored, and the statistics include but are not limited to latency, packet loss, throughput, jitter, top application, individual flows, number of sessions, and tunnel availability.
  • the GUI is configured to enable a user to create or trigger one or more network condition events on a running portion of the live network.
  • the network condition events include but are not limited to bringing down a link, changing latency of a link, changing capacity of a link, introducing packet loss on a link, and introducing jitter on a link.
  • a utility is presented that enables the user to bring down the link.
  • a link editor is presented that enables the user to specify new link latency and/or capacity.
  • a packet loss event when a user selects a link then a link editor is presented that enables the user to specify the packet-loss (or jitter) for that link.
  • the GUI is further configured to enable a user to specify security policies. For this capability, the GUI enables a user to select a packet type to be blocked on a running portion of the live network.
  • Networks are typically formed with one or more interconnected pathways.
  • items may travel along the various pathways.
  • a network may include more than one pathway from a first location to a second location.
  • the process of selecting among the two or more pathways for the item(s) to travel is termed“routing” for the purposes of this application. Routing may be performed for many kinds of networks, including a telephone network, transportation networks, and an electronic data network (such as a local area network, wide area network, intranet, extranet, or Internet).
  • the present invention is discussed in reference to routing certain types of items - specifically, information items - through certain types of networks - specifically, electronic data networks -, but the discussion is merely exemplary.
  • the present invention is applicable to routing movement of any type of item through any type of network.
  • certain embodiments of the present invention may be configured to address other multi-commodity flow problems such as traffic engineering road networks and commodity flow in the economy.
  • Electronic data networks may be comprised of at least a group of two or more nodes.
  • An example of a node is a physical electronic device (e.g., a router, computer, or switch).
  • a node also may be a virtual manifestation of such a device.
  • the term“node” is interchangeable with the term“router”.
  • information is transferred between nodes in a formatted unit of data, such as a packet, byte, character, datagram, or bit.
  • a formatted unit of data such as a packet, byte, character, datagram, or bit.
  • An information packet may be routed from a source node to a destination node. More specifically, the information packet may travel from a source node directly to a destination node or may travel from a source node to one or more intermediate nodes and then reach a destination node. For the purposes of this application, the portion of the route between each node and a second node is termed a“link”.
  • the specific nodes through which the information packet travels - which form the “pathway” - may be selected based on some criteria, such as shortest distance between source node and destination node or most bandwidth availability along the pathway.
  • Certain criteria information - e.g., distance between certain nodes - may be obtained and stored in a storage component. Examples of a storage component include a routing table, a topology map, a main memory, or secondary memory (the latter two of which are described in more detail below).
  • each node has its own storage component, which contains information regarding that node’s links to other nodes.
  • a storage component for a single node may include the information such as the distance between that single node and each other neighboring node.
  • a “neighboring node” is a node to which a source node can directly transfer information without need for an intermediate node.
  • link-state routing procedures Such procedures are configured to select pathways for the information packets based on the state of the links between nodes.
  • the term“link state” refers to a numerical description of the state of the link. It could be a number 1 to indicate a functioning link vs. a number 0 to indicate an inactive link.
  • the link state could be a valuation of the amount of traffic on the link.
  • the shortest distance between a source node and each other node in the network is calculated.
  • the distance may be considered a“price” for the purposes of the calculation.
  • a higher distance has a higher price, and a shorter distance has a lower price.
  • the procedure may seek to minimize the overall price of the set of links that form the pathway. Then, when an information packet travels through the selected pathway, it does so by traveling the shortest distance.
  • the pathway with the shortest distance may not be the most efficient pathway.
  • the most efficient pathway may get overburdened and become unable to support the quantity of information packets routed through that pathway.
  • more advanced systems and methods added additional criteria to calculate the“price” of the respective links and overall pathway.
  • such criteria may include available bandwidth between nodes, expected delay in communicating between nodes, pathway reliability, or pathway availability.
  • the route for the information packet is re-analyzed at each node. For example, at a source node, an evaluation is done to assess the“lowest price” second node in light of the ultimate destination node. A second assessment is done at the second node to determine the“lowest price” subsequent node in order to reach the destination node. The analysis is done at every subsequent node until the information packet reaches the destination node. This type of process is called“hop-by-hop” routing because a separate analysis is done relative to each node to determine each subsequent “hop” over a link.
  • Each network may include more than one packet travelling through the system.
  • the“hop-by-hop” routing procedures are limited in that they do not always achieve the optimal route over the entire pathway.
  • the analysis at node A includes an assessment whether node B or node C has a lower price.
  • the price of the link between node A and node B is rated 4, while the price of the link between node A and node C is rated 10. Accordingly, the analysis will identify node B as the lowest price subsequent node. Then, the analysis at node B will identify node D as the best subsequent node.
  • the overall price will be 18 (calculated by adding link price A-B, 4, and the price of link B to D, 14).
  • “optimized” or“optimal” routing procedures may include a method configured to achieve the most efficient mathematically/physically possible result for any identified objective (e.g. minimize total delay, maximize use of network resources, minimize distance traveled) or combination of objectives determined by a network operator.
  • the objectives may be prioritized by the system either in real- time as the system is processing the routes or by a list of priorities identified before the route processing begins.
  • the problem of optimizing network traffic is termed“traffic engineering” or“TE” for the purposes of this application.
  • Source routing An alternative to“hop-by-hop” routing is termed“source routing”, in which the entire route from the source node to the destination node is calculated by the source node.
  • Source routing can be difficult to implement, because the source node has to encode, in the information packet, the entire pathway that it must take through the network. This could potentially be more information than the payload of the packet.
  • Examples of source routing include the flow deviation technique, the gradient projection approach, and proximal decomposition methods.
  • these optimization procedures require the network to establish end-to-end virtual circuits or to encode the entire pathway each packet should take at the origin of that packet.
  • the established circuits become less useful and performance levels decrease.
  • efforts have been made to improve the optimality of traffic engineering in known hop-by-hop link-state procedures. For example, techniques have been shown to improve the performance of certain hop-by-hop link-state procedures - e.g., Open Shortest Path First (OSPF) - significantly by finding better weight settings for the procedure.
  • OSPF Open Shortest Path First
  • a “traffic matrix” is a matrix representation of the current traffic demand between the nodes in a network. While work has been done on traffic matrix estimation, even the best results have errors in the elements of the estimated traffic matrix on the order of 20% - difficulties which can lead to potentially bad traffic engineering.
  • Oblivious routing has been proposed to circumvent the need for estimating the traffic matrix for improved traffic engineering.
  • Such procedures seek to perform well regardless of the traffic demand by comparing the‘oblivious performance ratio’ of the routing, i.e., the worst case performance of the routing for a given network over all possible demands.
  • Examples of such procedures are a linear programming method to determine the best oblivious routing solution for the special case of minimizing maximum channel utilization and another procedure configured to maximize throughput for the special case of two phase routing.
  • hop-by-hop routing procedures are based on distance- vector methods.
  • Distance vector methods call for each router to send all or some portion of its routing table to other nodes, but only to its neighboring nodes.
  • one router started advertising to its neighboring nodes that it has essentially zero distance to all destinations.
  • the neighboring nodes started shifting traffic to this router followed by the neighboring nodes’ respective neighboring nodes.
  • the router went down under the traffic load but many routers in the Internet were still pointing or trying to point towards this router.
  • distance- vector procedures can converge slowly as packets need to be passed in a step-by-step manner from one end of the network to another for route computations to take place.
  • hop-by-hop link-state routing procedures that are not optimized are commonly used in many networks, despite not resulting in optimal use of network resources.
  • non-optimized procedures include the Open Shortest Path First (OSPF) procedure and the Intermediate System - Intermediate System (IS-IS) procedure.
  • OSPF Open Shortest Path First
  • IS-IS Intermediate System - Intermediate System
  • Certain embodiments of the present invention include a system and methods for routing items through a network.
  • MCF multi- commodity flow problem
  • KT Karush-Kuhn-Tucker
  • Certain embodiments of the present invention are configured to implement an adaptive, traffic-optimized, hop-by-hop, and link-state approach to solving the MCF problem in a network.
  • the system does not have to set up virtual circuits, end-to-end tunnels or encode the pathway the packet should follow at the origin.
  • some criteria or combination of criteria e.g., speed, reliability, or availability of the path - is maximized or minimized for the network or some portion of the network.
  • each node since the link-state approach is incorporated, each node has access to the state of each link and a single node cannot take down the network as with distance- vector implementations.
  • Certain embodiments of the present invention are also adaptive, and accordingly, configured to receive and process information regarding the changing state of links among nodes in the network.
  • system and methods of the present invention may be configured to implement the method in a“distributed” manner. More specifically, given the link-state information, each router may independently perform the relevant computations. However, this is a feature and not a requirement. The same calculations could be performed at any place with access to all the local node information such as the inflow rate and the split ratios.
  • Certain embodiments of the present invention include routing more than one information packet through a pathway in the network.
  • the optimal routing may include sending all the packets on the same pathway through the network - termed“single-path routing” - or sending certain packets on different pathways through the network - termed“multi -path routing”.
  • An optimal solution typically uses multiple paths between the source node and the destination node.
  • Certain embodiments of the present invention are configured to be implemented on a network running various types of routing systems and methods. Such embodiments may be configured to co-function with one or more single-path routers or multi-path routers in the same network. In other words, each router in a network may be configured to implement a routing method according to the present invention or routing methods outside the scope of the present invention.
  • the system and methods of the present invention is implemented in only a portion of the routers in a network, the performance of the network improves.
  • Certain embodiments of the present invention are configured to be“iterative”, which means that the system and methods are configured to dynamically adjust the traffic forwarding successfully at each node to seek the most optimal pathway.
  • the system may be understood by comparison to an example of another type of network - that is, a road network during rush hour.
  • Each driver may intend to drive their car from work to home, which is comparable to an information packet that needs to go from a source node to a destination node.
  • Car drivers typically prefer to use the shortest path back home to minimize their commute.
  • at rush hour there are many car drivers following the same strategy. Consequently, the major expressways get overcrowded and backed up, even though under non-rush hour circumstances those expressways would have indeed represented the fastest path for each driver to get home.
  • drivers may tune in to the radio and listen to the traffic report detailing the status of different roads that they can take to their destination.
  • the traffic report is comparable to the“link states” in embodiments of the present invention.
  • the car driver adaptively chooses which road to take at each junction of certain roads (“hop-by-hop” in the present invention) based on the incoming radio report so that they can get home quickly. Since multiple drivers are likely getting the same road traffic reports, a lot of car drivers might all choose to leave the expressway and take back roads to their destinations, which only makes traffic and delay significantly worse on those back roads.
  • this problem is managed by a method step that splits the traffic at junctions based on their destination so that not everybody piles onto the same alternative route. The exact splits are determined iteratively and dynamically to optimize the traffic flow based on the traffic conditions reported via the radio reports/link states.
  • OSPF which controls routing on over 95% of the Internet, relies on these link-state updates.
  • OSPF relies on reports that include pre-computed weights that are operator specific. The weights may be an inverse of the link bandwidth, or some number assigned based on statistical/historical knowledge of the traffic conditions on the link.
  • one type of improved report may indicate the number of packets (e.g., cars in the road example) between two junctions (e.g., intersections in the car example), while another type of improved report may indicate the number of packets per unit of distance (or cars per mile) between two junctions.
  • Each report conveys different information.
  • the link-state is reported to achieve optimal performance.
  • certain embodiments of the present invention include a number of method steps.
  • a method may begin with ascertaining one or more links between two nodes in a network.
  • a price value may be assigned to each link between the one or more nodes.
  • the price value of the respective links may be shared among certain or all nodes in the network.
  • the optimal subsequent node i.e., next hop
  • each packet may be calculated. The calculation is repeated at each subsequent node until the destination node is reached.
  • each node includes its own processor and main memory (each of which is described in more detail later in the application) configured to implement the entire method.
  • certain steps are done in one processor and information about those steps is communicated to processors in one or more nodes.
  • One object of certain embodiments of the present invention is improved performance relative to known procedures for optimized traffic engineering.
  • Another object of certain embodiments of the present invention is improved performance by upwards of 1000% relative to known procedures for optimized traffic engineering.
  • Another object of certain embodiments of the present invention is easier implementation of the system and methods relative to known procedures for optimized traffic engineering.
  • Another object of certain embodiments of the present invention is easier management of the system and methods relative to known procedures for optimized traffic engineering.
  • Another object of certain embodiments of the present invention is improved overall traffic engineering relative to known hop-by-hop procedures, link-state procedures, or hop-by-hop and link-state procedures.
  • Yet another object of certain embodiments of the present invention is that it does not require estimating a traffic matrix.
  • Yet another object of certain embodiments of the present invention is that it does not require source routing.
  • Yet another object of certain embodiments of the present invention is easier scalability, e.g., scaling up or scaling down as needed for the size of a network, relative to known procedures.
  • Yet another object of certain embodiments of the present invention is to use the same inputs used in OSPF or IS-IS to facilitate easier transition between networks currently utilizing OSPF or IS - IS procedures.
  • a difference between certain embodiments of the invention and existing link-state procedures is an argument for how to control the ratio according to which an internet router splits traffic to a destination across its outgoing links. Since it needs no additional input and can work with existing infrastructure, implementing embodiments of the invention would include modifying the component of the router running OSPF to run such embodiments of the invention. For practical implementation, a discrete-time version of the continuous-time argument is necessary. However, since the continuous time argument has been shown to be valid, it is only a question of selecting a small enough step-size to implement the present invention. In other words, the step-size includes using discrete time steps instead of continuous time. A digital implementation requires time steps to operate, whereas an analog implementation does not require time steps to operate. Since computers are digital, discrete time steps are typically required.
  • the invention can be distributed as a software service, a hardware component configured to implement the method, or as a full-scale router.
  • MCF multi-commodity flow
  • Commodities are defined in terms of their final destination t. ' u v is the flow on link ( u,v ) corresponding to commodity t and f,.v is the total flow on link (it, v).
  • the price at a node can be interpreted as the average price to the destination from that node where the average is taken over all outgoing edges to the destination weighted by the split ratios along those edges.
  • split ratio the selection of which packets or how many packets follow which path through which nodes.
  • a split ratio may be determined for each commodity (e.g., information packet) at every node. More specifically, each router’s split ratios are adjusted and traffic is moved from one outgoing link to another. Such embodiments only control the next hop on a packet path, which is hop-by-hop routing. If the entire path rate was controlled, the system would be using source routing. Also, the split ratio determination may include favoring links that form the shortest pathway, even though the average price via the next hop node may not be the lowest.
  • Gallager a distance vector solution
  • the dashed line represents Gallager’s approach and the solid line represents an embodiment of the present invention.
  • the split ratio determination may include adapting the split ratios dynamically and incrementally by decreasing the packet traffic along links that belong to non-shortest paths while increasing along the link that is part of the shortest path at every router.
  • split ratios are set to send packets only to the links leading to the currently calculated shortest path, then the result is OSPF with weights, w u,v.
  • Certain portions of certain embodiments of the present invention are configured to address specific scenarios that may occur in a network.
  • One scenario is illustrated in Figure 51A.
  • One or more information packets 52 are available for routing through the network 50.
  • the rate of demand 53 for routing information packets 52 may be represented by“r”.
  • the one or more information packets 52 may be sent along a first link 54 or a second link 56.
  • the first link 54 has a more expensive“price” according to some criteria (e.g., longer distance, lower reliability, etc.).
  • the more expensive price is represented by the character“w / ”.
  • the second link 56 has a less expensive price and is represented by the character V.
  • a strategy to reach optimal use of the first link and the second link might be to dynamically shift traffic from the more expensive link to the cheaper link at some rate d > 0 until the prices of the two links become the same.
  • the split ratio for the first link 54 at node A is represented by m and the split ratio for the second link 56 is represented by a s.
  • the traffic over the first link 54 is decreased and traffic at the second link is increased.
  • the m value may be decreased while the a s value is increased at rate d / r.
  • a second interpretation which is the basis of certain embodiments of the present invention, is that the router shifts traffic from links along more expensive paths to the link along the path with the lowest price.
  • the following update rule for the split ratios is:
  • Figure 51B illustrates traffic demand of rate r from node A to node C.
  • node A node
  • node B node
  • node C node C
  • first link 54 between node B and node C
  • second link 56 between node B and node C
  • third link 58 between node A and node B
  • fourth link 60 between node A and node C.
  • the relationship between the initial link prices are assumed to be wi > w m > w s + W B , i.e., the third link ( A,B ) is along the shortest path from node A to node C, but node B also has the most expensive way to reach node C.
  • Figure 51B can be used to illustrate the difference between certain embodiments of the present invention and Gallager’s technique which arises from the fact that the link leading to the neighbor with the lowest average price (path A-C with price w m ) may not lead to the cheapest path (path A-B-C with price W B + w s ).
  • Figure 52 shows the trajectories taken by the two different methods to converge to the optimal solution for the illustrated topology.
  • an intermediate dummy node D may be introduced that splits the bottom link between B and C into two equal capacity links.
  • the split ratios to a given destination have to add up to the value 1. Accordingly, only one split ratio is calculated at each node because the value of that split ratio automatically defines the value of the other at each node.
  • Gallager’s method initially, as can be seen, following the lowest average price path to the destination ( A,C ), there is an increase in the value of a m.
  • the trajectory of the method is perpendicular to the objective function contour curves.
  • both split ratios are decreased initially.
  • the trajectory based on an embodiment of the present invention is usually not perpendicular to the contour curves, which represent the cost of the network. However, the trajectory still goes along a descent direction and drives the total cost down.
  • Figure 51C The scenario illustrated in Figure 51C is configured to exemplify why Equation 3 is not sufficient to decrease network cost along any trajectory.
  • Figure 51C illustrates k intermediate price links from router A to router C, each of which gets
  • the scenario in Figure 51D includes multiple inputs.
  • the link weights as illustrated are wi > w m > w s + WB.
  • 3 ⁇ 4 k while for a general network, 3 ⁇ 4 may be calculated according to a method specified later in this application. The calculation for determining the routing of information packets is updated to:
  • embodiments of the present invention results in split ratios for all the links converging to a set where every element of the set achieves the global optimum to the MCF problem and accordingly achieves optimal traffic engineering for the network.
  • every element of the set achieves the global optimum to the MCF problem and accordingly achieves optimal traffic engineering for the network.
  • the character a is also used without indexing to represent the set of all the split ratios from all the routers in the network.
  • a router w controls the fraction of traffic to destination I that uses outgoing link (u, v ) while satisfying
  • Branch cardinality is used to make sure that nodes that are farther away from a destination node are more conservative in how much traffic they shift to the shortest path leading to the destination. As noted earlier, if nodes simply shifted a large percentage or all of their traffic to the shortest node, the performance of the network would be poor. OSPF is an example of the latter.
  • the characters % which represent the branch cardinality, are defined as the product of the number of branches encountered in traversing the shortest path tree (e.g., route) rooted at t from t to it. Being a link-state routing method, each node u has the link-state information to run Dijkstra’s method to compute the shortest path tree to destination t.
  • node index is an identifier that uniquely describes each node in a network. Examples include a MAC address, IP address, etc.
  • the overall link-state routing method can be used to control the evolution of the destination specific split ratio Q A for any node u.
  • (w, ⁇ ) G E and (it, ⁇ ) is part of the shortest path to t from u.
  • certain embodiments of the present invention calculate the split ratios as follows.
  • each node checks to see whether it has traffic to a given destination. If it does not already have traffic going to a destination, it forwards all newly received packets to that destination along the shortest path to that destination. If it does already have traffic going to a destination, it adjusts what fraction of traffic it forwards along its different outgoing links according to the equations. As noted in the case studies earlier, it reduces the traffic along non-shortest paths and increases it along the outgoing link leading to the currently calculated shortest path. This procedure is iteratively followed until the optimal solution is obtained.
  • the first Lemma relates the node prices to the link weights for each destination t. More specifically,
  • the second Lemma captures the fact that the change in network cost can either be expressed in terms of the change in the link flow rates, i.e., how each link affects the network cost or in terms of the change in the split ratios at each node, i.e., how each node affects the network cost.
  • step 1 First in this part of the method is step 1, in which the following is true.
  • This part of the step 1 method is configured to decompose the change in cost to a particular destination /, by grouping the terms from the summation derived in Lemma 2, using the branches of the shortest path tree rooted at that destination. More precisely, a branch (B) is defined as the set of nodes on the path from a leaf node on the shortest path tree to the destination node t. Given the definition, some intermediate nodes clearly will be shared among multiple branches. The change in cost contributed by these nodes is properly divided among the different branches that pass through these routers in the following way. Each node u has a corresponding % *, value which appears in the denominator of the expression for the change in cost. When grouping terms, for a particular branch passing through an intermediate node, to only take a fraction, ’ of the change in cost contributed by the intermediate node, to be summed with that
  • L ! n u is the fraction of the change in cost due to node u that it contributes to the branch summation.
  • the character h will be used to represent every router u that belongs to the branch B. For any M £ ⁇ 1, 2, ... - 1 ⁇ , the following equation applies:
  • the change in cost along a branch B is zero only when all the traffic from the nodes that belong to the branch is being routed to the destination through shortest paths with respect to the link prices. Since this is a necessary and sufficient condition for optimality in MCF, the proof is complete.
  • a sample shortest path tree is analyzed and the corresponding cost change calculations are identified explicitly.
  • a shortest path tree is illustrated in Figure 53.
  • the number of branches that the tree is divided into is determined by the number of leaf nodes.
  • the shortest path tree rooted at t has 12 leaf routers and, consequently, the summation is divided into 12 branches.
  • the change in the cost function due to the routers increasing traffic along the links in the shortest path tree can be calculated using Lemma 2.
  • the terms in the summation are divided and grouped per branch. For routers downstream to a leaf router in a branch, only a fraction of the change in the cost contributed by the downstream router is selected where the fraction is determined by the need to have the same h for all routers in the summation for a branch.
  • the contribution to the change in the cost by the routers for the highlighted branch can be calculated as follows,
  • the initial routes supplied to the different methods are Figure 54B includes a graph of solutions provided by an embodiment of the present invention - designated as“HALO”.
  • a“single-path method used to make routing decisions” is a router that uses a set of link weights to calculate the shortest path to the destination and makes forwarding decisions based on that shortest path. Also, if the single-path router calculations are triggered as often as that in the present invention, examples can be illustrated in which the routes in the network will oscillate and not settle down. This is because the single- path method moves all the traffic from one path to another instead of just a fraction. Also, a notion of time-scale separation between how often the method of the present invention is triggered and the single-path method is triggered.
  • the subset of routers running the present invention will execute the method in between slower single- path calculations. Given this set up, the two methods can work with either the same link weights or method-specific link weights. Since local optimization methods exist for calculating single-path method link weights, and because method-specific calculations can be triggered on the receipt of new method-specific link weights, the use of method- specific link weights generally broadcast by each router at different timescales. However, this assumption is more important from an implementation perspective than for the argument that follows.
  • Another useful assumption is that each router is aware of the method that the other routers in the network are using.
  • the‘single-path’ routers have a pruning effect on the network from the perspective of the routers running an embodiment of the present invention, i.e., the outgoing links that are not used by them are effectively not a part of the network topology.
  • the nodes running embodiments of the present invention will base their calculations on this reduced network and attain the optimal routing solution for this network.
  • the routers implementing an embodiment of the present invention increase the search space for finding a better routing solution and thus improve network performance.
  • Certain embodiments of the present invention can be evaluated for certain performance metrics, specifically, the optimality, rate of convergence to the optimal solution, adaptivity as the traffic changes, and asynchronous environments and its interaction with single path routing methods.
  • the evaluations may be performed on three network topologies - the benchmark Abilene network (Figure 55), a 4 x 4 Mesh network and a two-level hierarchical 50 node network.
  • the 4 x 4 Mesh network may be selected to study the effects of intermediate routing loops on the optimality of the present invention as this topology is particularly prone to such loops while the hierarchical network may be selected to mimic larger networks with high capacity backbone links and lower capacity local links.
  • Randomly generated traffic demands may be used for the mesh network and the hierarchical network while for the Abilene network uniform traffic demand is used. In any of the three cases, the demand may be scaled up until at least one link in the network is close to saturation at the optimal solution.
  • the speed of convergence depends on the step-size.
  • the step size is the unit of time with which the changes in the split ratios calculated in Equations (6) - (9) are multiplied to determine how much to vary the split ratios from one time slot to the next.
  • the metric network load is defined as the ratio of the total traffic on the network to its total capacity.
  • the maximum network load for the Abilene network may be 24.6%
  • mesh network may be 26.1%
  • the hierarchical network may be 5.3%. These values indicate the point at which further scaling up the demand for the given traffic pattern would exceed the capacity of at least one link in the network, even with optimal routing. From Figure 56, it is clear that the system and methods take more iterations to converge to the optimal solution for more heavily loaded networks. The present invention converges to the optimal solution on the order of a thousand iterations. Given that link-state advertisements can be broadcast on the order of milliseconds, the possibility of convergence times of less than a second to a few seconds for the method on networks where transmission/propagation delay of the link-state advertisements is not a limiting factor.
  • the optimal solution may be calculated for the test networks by solving the corresponding MCF problem using CVX method known in the art or another method known in the art under different network load conditions.
  • the objective value obtained by using the present invention matched the optimal solution for each test case as can be seen from Figures 58A-58C.
  • the intermediate routing loops produced while determining the optimal solution for the mesh network did not affect the optimality of the system and methods.
  • Figure 59 the performance of an embodiment of the present invention is compared with OSPF boosted by better weight settings obtained from the methods of the TOTEM toolbox for demand matrices that placed increasing loads on the test networks.
  • the local search method used by TOTEM minimizes a piecewise-linear approximation of the convex cost function.
  • the power of optimality is demonstrated by the performance improvements on the order of 1000%.
  • Figure 60 illustrates the evolution of the optimality gap as a traffic matrix undergoes changes under different network load conditions in the Abilene network. In this example, after around 300 iterations the network load is changed by changing 20% of the flows in the network.
  • the method quickly adapts and the optimality gap increases very little before beginning to converge to the new optimal solution.
  • the traffic pattern is again changed by varying 50% of the flows in the network after 800 iterations. This time the change in the optimality gap is greater but the convergence to the new optimal value is seen to be quicker.
  • the traffic pattern in the network is changed two more times and as can be observed from the figure in both cases the method quickly converges to the new optimal solution.
  • a closely related concept to certain embodiments of the system and methods of the present invention is the evolution of the split ratios at individual routers.
  • a plot of the evolution of the split ratios from Indianapolis to Los Angeles is illustrated in Figure 60B.
  • the initial sub-optimal allocation of split ratios is quickly corrected as the present invention reduces traffic sent to Chicago and increases traffic sent to Kansas City and Atlanta.
  • Figure 62A illustrates data regarding how the present invention may operate in the presence of asynchronous link-state updates and asynchronous executions, using uniform traffic on the Abilene network.
  • the nodes in the network could be numbered and divided into two groups. For asynchronous link-state updates, at every iteration, the even numbered nodes may receive link-states without any delay while the odd numbered nodes may receive link-states from the even numbered nodes after a fixed delay. Consequently, at each execution of the method, the two sets of nodes could have different views of the network link-states. The fixed delay could then be varied to generate the results reported in Figure 62A.
  • the odd numbered nodes could be forced to execute the steps of the present invention slower than the even numbered nodes.
  • the difference in the rate of execution was varied in order to obtain the results reported in Figure 62B. Different step-sizes could be used to prevent oscillations in the two cases.
  • the embodiment of the present invention still converges to within 1% of the optimal solution. Additionally, there may be a steady increase in the number of iterations required by the embodiments of the present invention as the delay in propagating the link-states or the difference in the rate of executing the present invention increases.
  • Figure 63 illustrates the topology of an embodiment of the present invention. More specifically, the illustrated network includes a first node 80A (also called node A), a second node 80B(also called node B), a third node 80C (also called node C), and a fourth node 80D (also called node D), however, a network 50 may include any number of nodes 80. Each network node 80 has two ports 82. Each node 80 may be connected to a NetFPGA 1G platform configured to act as a router.
  • the NetFPGA is a generally reconfigurable hardware platform configured for high speed networking.
  • a NetFPGA platform includes all of the logic resources, memory and Gigabit Ethernet interfaces to build a complete switch, router, and/or security device. Because the entire datapath may be implemented in hardware, the NetFPGA platform may support back-to-back packets at full Gigabit line rates and has a processing latency measured in only a few clock cycles.
  • An exemplary embodiment of a NetFPGA includes a field programmable gate array logic, Gigabit Ethernet networking ports, static random access memory, double-date rate random access memory, Multi-gigabit I/O, standard PCI form factor, hardware debugging ports, and flexible code.
  • packet forwarding decisions may be transferred from the firmware to higher level software, which could be easily modified via SCONE (Software Component of NetFPGA).
  • SCONE Software Component of NetFPGA
  • a new table may be added to the software to store the split ratios in addition to the routing table provided in the reference router implementation for the NetFPGA platform. Then a random number generator may be used in conjunction with the routing table and the split ratios table to forward traffic as needed.
  • the link-state update packets are modified to be broadcast frequently enough to ensure relatively quick convergence of the method and to modify their payload to transmit the link rates.
  • the link-states may be set to broadcast every 250 milliseconds.
  • the network cost function may be represented as w hich results in 2f u,v as the price of each link.
  • Other components of the method such as retrieving the incoming rate into each board and the outgoing rate on each link can be easily obtained from the NetFPGA registers.
  • Dijkstra’s method is changed to run with the new link weights instead of hop-count as it was doing in the Reference Router implementation in SCONE.
  • video traffic may be sent using, for example, a VLC Media Player as a video server from node B to node C.
  • KKT conditions of the multi-commodity flow problem are what permit focusing on shortest paths based on the price and use that to claim optimality of the method. From the KKT conditions of the MCF problem, for the given cost function, it is easy to see that the values of the split ratios at optimality should be (X B A ⁇ and c
  • certain embodiments of the present invention include an optimal, link-state, hop-by-hop routing method.
  • certain embodiments of the present invention may facilitate capital savings for ISPs by reducing investments in infrastructure to keep utilization of the networks manageable by current suboptimal procedures).
  • the present invention may facilitate performance benefits for consumers.
  • FIG. 67 illustrates such an exemplary computer system 200.
  • One or more computer systems 200 may carry out the methods presented herein as computer code.
  • Computer system 200 includes an input/output display interface 202 connected to communication infrastructure 204 - such as a bus -, which forwards data such as graphics, text, and information, from the communication infrastructure 204 or from a frame buffer (not shown) to other components of the computer system 200.
  • the input/output display interface 202 may be, for example, a keyboard, touch screen, joystick, trackball, mouse, monitor, speaker, printer, Google Glass® unit, web camera, any other computer peripheral device, or any combination thereof, capable of entering and/or viewing data.
  • Computer system 200 includes one or more processors 206, which may be a special purpose or a general-purpose digital signal processor that processes certain information.
  • Computer system 200 also includes a main memory 208, for example random access memory (“RAM”), read-only memory (“ROM”), mass storage device, or any combination thereof.
  • Computer system 200 may also include a secondary memory 210 such as a hard disk unit 212, a removable storage unit 214, or any combination thereof.
  • Computer system 200 may also include a communication interface 216, for example, a modem, a network interface (such as an Ethernet card or Ethernet cable), a communication port, a PCMCIA slot and card, wired or wireless systems (such as Wi-Fi, Bluetooth, Infrared), local area networks, wide area networks, intranets, etc.
  • main memory 208, secondary memory 210, communication interface 216, or a combination thereof function as a computer usable storage medium, otherwise referred to as a computer readable storage medium, to store and/or access computer software including computer instructions.
  • a computer readable storage medium do not include any transitory signals or waves.
  • computer programs or other instructions may be loaded into the computer system 200 such as through a removable storage device, for example, a floppy disk, ZIP disks, magnetic tape, portable flash drive, optical disk such as a CD or DVD or Blu-ray, Micro-Electro-Mechanical Systems (“MEMS”), nanotechnological apparatus.
  • MEMS Micro-Electro-Mechanical Systems
  • computer software including computer instructions may be transferred from the removable storage unit 214 or hard disc unit 212 to the secondary memory 210 or through the communication infrastructure 204 to the main memory 208 of the computer system 200.
  • Communication interface 216 allows software, instructions and data to be transferred between the computer system 200 and external devices or external networks.
  • Software, instructions, and/or data transferred by the communication interface 216 are typically in the form of signals that may be electronic, electromagnetic, optical or other signals capable of being sent and received by the communication interface 216. Signals may be sent and received using wire or cable, fiber optics, a phone line, a cellular phone link, a Radio Frequency (“RF”) link, wireless link, or other communication channels.
  • RF Radio Frequency
  • Computer programs when executed, enable the computer system 200, particularly the processor 206, to implement the methods of the invention according to computer software including instructions.
  • the computer system 200 described herein may perform any one of, or any combination of, the steps of any of the methods presented herein. It is also contemplated that the methods according to the invention may be performed automatically, or may be invoked by some form of manual intervention.
  • the computer system 200 may be a handheld device and include any small-sized computer device including, for example, a personal digital assistant (“PDA”), smart hand-held computing device, cellular telephone, or a laptop or netbook computer, hand held console or MP3 player, tablet, or similar hand held computer device, such as an iPad ® , iPad Touch ® or iPhone ® .
  • PDA personal digital assistant
  • smart hand-held computing device such as an iPad ® , iPad Touch ® or iPhone ®
  • cellular telephone such as an iPad ® , iPad Touch ® or iPhone ®
  • laptop or netbook computer such as an iPad ® , iPad Touch ® or iPhone ®
  • Figure 68 illustrates an exemplary cloud computing system 300 that may be used to implement the methods according to the present invention.
  • the cloud computing system 300 includes a plurality of interconnected computing environments.
  • the cloud computing system 300 utilizes the resources from various networks as a collective virtual computer, where the services and applications can run independently from a particular computer or server configuration making hardware less important.
  • the cloud computing system 300 includes at least one client computer 302.
  • the client computer 302 may be any device through the use of which a distributed computing environment may be accessed to perform the methods disclosed herein, for example, a traditional computer, portable computer, mobile phone, personal digital assistant, tablet to name a few.
  • the client computer 302 includes memory such as random access memory (“RAM”), read-only memory (“ROM”), mass storage device, or any combination thereof.
  • RAM random access memory
  • ROM read-only memory
  • the memory functions as a computer usable storage medium, otherwise referred to as a computer readable storage medium, to store and/or access computer software and/or instructions.
  • the client computer 302 also includes a communications interface, for example, a modem, a network interface (such as an Ethernet card), a communications port, a PCMCIA slot and card, wired or wireless systems, etc.
  • the communications interface allows communication through transferred signals between the client computer 302 and external devices including networks such as the Internet 304 and cloud data center 306. Communication may be implemented using wireless or wired capability such as cable, fiber optics, a phone line, a cellular phone link, radio waves or other communication channels.
  • the client computer 302 establishes communication with the Internet 304 - specifically to one or more servers - to, in turn, establish communication with one or more cloud data centers 306.
  • a cloud data center 306 includes one or more networks 3 lOa, 3 lOb, 3 lOc managed through a cloud management system 308.
  • Each network 3 lOa, 3 lOb, 3 lOc includes resource servers 3 l2a, 3 l2b, 3 l2c, respectively.
  • Servers 3 l2a, 312b, 312c permit access to a collection of computing resources and components that can be invoked to instantiate a virtual machine, process, or other resource for a limited or defined duration.
  • one group of resource servers can host and serve an operating system or components thereof to deliver and instantiate a virtual machine.
  • Another group of resource servers can accept requests to host computing cycles or processor time, to supply a defined level of processing power for a virtual machine.
  • a further group of resource servers can host and serve applications to load on an
  • instantiation of a virtual machine such as an email client, a browser application, a messaging application, or other applications or software.
  • the cloud management system 308 can comprise a dedicated or centralized server and/or other software, hardware, and network tools to communicate with one or more networks 3 lOa, 3 lOb, 3 lOc, such as the Internet or other public or private network, with all sets of resource servers 3 l2a, 3 l2b, 3 l2c.
  • the cloud management system 308 may be configured to query and identify the computing resources and components managed by the set of resource servers 3 l2a, 3 l2b, 3 l2c needed and available for use in the cloud data center 306.
  • the cloud management system 308 may be configured to identify the hardware resources and components such as type and amount of processing power, type and amount of memory, type and amount of storage, type and amount of network bandwidth and the like, of the set of resource servers 3 l2a, 3 l2b, 3 l2c needed and available for use in the cloud data center 306.
  • the cloud management system 308 can be configured to identify the software resources and components, such as type of Operating System (“OS”), application programs, and the like, of the set of resource servers 3 l2a, 3 l2b, 3 l2c needed and available for use in the cloud data center 306.
  • OS Operating System
  • the cloud computing system 300 of Figure 68 is provided only for the purposes of illustration and does not limit the invention to this specific embodiment. It is appreciated that a person skilled in the relevant art knows how to program and implement the invention using any computer system or network architecture.
  • Embodiments include a system comprising a plurality of nodes configured to form a network comprising a plurality of virtual links in an overlay network provisioned over an underlay network including servers of a public network.
  • the system includes a plurality of virtual routers (VRs) at each node.
  • Each VR is coupled to the network and to a tenant of a plurality of tenants of the node, and configured to form in the network a set of virtual links corresponding to the tenant.
  • At least one VR includes a feedback control system comprising at least one objective function that characterizes the network.
  • the VR is configured to receive link state data of the set of virtual links and control routing of a tenant traffic flow of each tenant according to a best route of the network determined by the at least one objective function using the link state data.
  • Embodiments include a system comprising: a plurality of nodes configured to form a network comprising a plurality of virtual links in an overlay network provisioned over an underlay network including servers of a public network; and a plurality of virtual routers (VRs) at each node, wherein each VR is coupled to the network and to a tenant of a plurality of tenants of the node, and configured to form in the network a set of virtual links corresponding to the tenant, wherein at least one VR includes a feedback control system comprising at least one objective function that characterizes the network, wherein the at least one VR is configured to receive link state data of the set of virtual links and control routing of a tenant traffic flow of each tenant according to a best route of the network determined by the at least one objective function using the link state data.
  • VRs virtual routers
  • Each node includes a plurality of virtual machines (VMs), wherein each VM includes a VR of the plurality of VRs and corresponds to the tenant.
  • VMs virtual machines
  • Each VM is configured to isolate at least one of a control plane and a data plane of each tenant from each other tenant of the plurality of tenants.
  • the control of the routing of the tenant traffic flow comprises routing the tenant traffic flow from an ingress note to an egress node of the plurality of nodes.
  • the control of the routing of the tenant traffic comprises each VR separately controlling routing of each tenant traffic flow to at least one next node of the best route.
  • the plurality of virtual links is a component of the overlay network and utilizes the underlay network for delivery of the tenant traffic flow.
  • the set of virtual links are configured to form a private tenant network corresponding to the tenant.
  • the plurality of virtual links comprises a plurality of single-hop virtual links coupled between each node of the plurality of nodes.
  • the plurality of virtual links include a plurality of sets of virtual links, wherein each set of virtual links forms a private tenant network of a corresponding tenant of the plurality of tenants.
  • the network includes a plurality of private tenant networks corresponding to the plurality of tenants, wherein each private tenant network is isolated from each other private tenant network of the plurality of private tenant networks.
  • the plurality of private tenant networks is configured to maintain separation of multi-tenant traffic flows throughout the network.
  • Each private tenant network is configured with a tenant configuration of a corresponding tenant to control routing of tenant traffic flows of the tenant.
  • the tenant configuration includes traffic classification data, route data, and bandwidth.
  • Each VR comprises a plurality of routing control algorithms representing a plurality of routing behaviors.
  • Each routing control algorithm is configured to determine at least one path through the network for routing the tenant traffic flow from an ingress node of the plurality of nodes to an egress node of the plurality of nodes.
  • Each routing behavior corresponds to a traffic classification of the tenant traffic flow.
  • Each routing behavior is defined by an objective function of a plurality of objective functions, wherein the plurality of objective functions include the at least one objective function.
  • the VR is configured to apply a corresponding objective function to the link state data and generate a link weight for each link of the set of links.
  • the VR is configured to determine the best route of the tenant traffic flow according to link weights of the set of links.
  • the control of the routing of the tenant traffic flow comprises continually adapting the at least one route in response to changes in the link state data as processed by the corresponding objective function.
  • the VR is configured to periodically receive link state updates that include updated link state data of the set of virtual links.
  • the continually adapting of the at least one route comprises applying the corresponding objective function to the updated link state data.
  • the VR is configured to apply the corresponding objective function to the updated link state data and generate an updated link weight for each link of the set of links.
  • the VR is configured to determine an updated best route of the tenant traffic flow according to updated link weights of the set of links.
  • Each VR of a set of VRs each includes the feedback control system comprising the at least one objective function that characterizes the network.
  • Each VR of the plurality of VRs includes the feedback control system comprising the at least one objective function that characterizes the network.
  • the plurality of routing behaviors includes routing a tenant traffic flow via multiple paths of the network.
  • the plurality of routing behaviors includes routing a tenant traffic flow directly via a shortest path of the network.
  • the plurality of routing behaviors includes routing a tenant traffic flow on a path and maintaining the tenant traffic flow on the path until detection of an network event.
  • the network event includes at least one of a network topology change and a variation in the link state data exceeding a pre-specified threshold.
  • the best route includes at least one lowest cost path based on the link state data.
  • the link state data of each link represents at least one link metric of the link.
  • the at least one link metric includes at least one of latency, jitter, packet loss, throughput, utilization, link state, and link status.
  • Each VR is configured to maintain configuration data for the corresponding tenant, and to use the configuration data in the control of the routing of the tenant traffic flow.
  • the configuration data includes traffic class configuration data.
  • the traffic class configuration data identifies traffic classes, and configures MCN behavior corresponding to each traffic class.
  • the configuration data includes route configuration data.
  • the route configuration data includes data of a service that is a recipient of the tenant traffic flow.
  • Each VR is configured to maintain topology data including a logical view of the overlay network for the corresponding tenant, and to use the topology data in the control of the routing of the tenant traffic flow.
  • Each VM includes a monitoring agent coupled to the VR, wherein the monitoring agent is configured to collect data representing the link state data of the set of virtual links of the overlay network.
  • the data representing the link state data of the set of virtual links includes at least one link metric of the set of virtual links.
  • the at least one link metric includes at least one of latency, jitter, packet loss, throughput, utilization, link state, and link status.
  • Each monitoring agent is configured to collect the at least one link metric from at least one of a plurality of monitoring agents and a plurality of VRs of the plurality of VMs.
  • the VR is configured to configure the set of virtual links for use by the monitoring agent.
  • Each monitoring agent is configured to collect the at least one link metric using probe signals exchanged with others of the plurality of VMs.
  • Each VM is configured to send the at least one link metric to the monitoring agent transmitting the probe signals in response to receipt of the probe signals.
  • the monitoring agent is configured to generate the link state data of the set of virtual links by processing the at least one link metric.
  • the VR is configured to receive from the monitoring agent the link state data of the set of virtual links.
  • Each VR is configured to receive the link state data of others of the plurality of links from others of the plurality of VRs.
  • Each VM includes a virtual gateway coupled to the corresponding tenant and the corresponding VR, wherein the virtual gateway is configured to control tenant traffic flows incoming to the VM from the corresponding tenant.
  • the virtual gateway is coupled to the monitoring agent.
  • the VR is configured to generate at least one set of flow rules configured to control the routing of the tenant traffic flow through the overlay network.
  • the at least one set of flow rules corresponds to the at least one objective function.
  • the virtual gateway is configured to attract tenant traffic flows of the
  • the virtual gateway is configured to reject traffic flows arriving from sources other than the corresponding tenant.
  • Each VM includes a set of public IP addresses, wherein the set of public IP addresses is dedicated to the corresponding tenant, wherein the corresponding tenant accesses the virtual gateway of the VM using the set of public IP addresses.
  • the system comprises at least one virtual switch coupled to the VR and the virtual gateway of each VM.
  • the at least one virtual switch includes a set of routing tables representing the at least one set of flow rules.
  • the set of routing tables is configured to manage the control of the routing of the tenant traffic flow through the network.
  • the at least one virtual switch is configured to transfer the tenant traffic flow between the virtual gateway and the VR.
  • At least one of the virtual gateway, the VR, and the at least one virtual switch are configured to form the set of virtual links.
  • the system comprises an aggregator coupled to the at least one virtual switch.
  • the aggregator is configured to route via the set of virtual links the tenant traffic flow received at the virtual gateway from the corresponding tenant.
  • the aggregator is configured to route to the corresponding tenant the tenant traffic flow received at the node via the network.
  • the tenant traffic flow arriving at the aggregator via the network is routed to the corresponding tenant via at least one of the corresponding VR and the virtual gateway.
  • the virtual gateway routes the tenant traffic flow arriving at the aggregator to the tenant via a coupling over a public network.
  • Each node includes an aggregator coupled to the at least one virtual switch and the network.
  • the aggregator is configured to route via the network the tenant traffic flows of the plurality of tenants corresponding to the node.
  • Each node includes a hypervisor, wherein the hypervisor is configured as an operating system of the plurality of VMs of the node.
  • the hypervisor is configured to include the at least one virtual switch.
  • the hypervisor is configured to include the aggregator.
  • the system comprises a provisioner coupled to the plurality of VMs of the plurality of nodes, wherein the provisioner is configured to control provisioning of at least one of the overlay network and the underlay network.
  • the provisioner is coupled to a queue comprising at least one pre-provisioned network, wherein the control of the provisioning of the underlay network includes use of a pre-provisioned network of the queue as the underlay network.
  • the provisioner is configured to control configuration of the plurality of VMs of the plurality of nodes.
  • the provisioner is configured to control configuration of components of each VM of the plurality of VMs using a tenant configuration of the corresponding tenant.
  • the provisioner is configured to generate routes corresponding to each of the plurality of tenants.
  • the provisioner is configured to maintain network data of at least one of the overlay network and the underlay network, wherein the network data includes data representing the overlay network, the underlay network, route configurations, topology data of the network including the plurality of virtual links, and tenant configurations of the plurality of tenants.
  • the system comprises a web application coupled to the provisioner, wherein the web application is configured to generate a user interface configured to generate for presentation prompts for data representing the tenant configuration, and to receive data input of the tenant.
  • the web application is configured to maintain link state data of the plurality of virtual links, and link metrics represented by the link state data.
  • the web application includes an alerts engine configured to generate and manage alerts and notifications, wherein the alerts and notifications correspond to at least one of the link state data and the link metrics.
  • Embodiments include a system comprising a plurality of nodes configured to form a network comprising virtual links.
  • the system includes a plurality of virtual machines (VMs) at each node.
  • Each VM is coupled to the network and to a tenant of a plurality of tenants of the node.
  • the system includes a feedback control system in at least one VM, comprising a plurality of objective functions representing a plurality of routing behaviors.
  • Each objective function is configured to continually characterize the network per traffic flow based on link state data of the virtual links received from a set of the VMs.
  • the feedback control system determines based on the characterization a best route through the network, and controls routing of each traffic flow to at least one next node of the best route.
  • Embodiments include a system comprising: a plurality of nodes configured to form a network comprising virtual links; a plurality of virtual machines (VMs) at each node, wherein each VM is coupled to the network and to a tenant of a plurality of tenants of the node; and a feedback control system in at least one VM, comprising a plurality of objective functions representing a plurality of routing behaviors, wherein each objective function is configured to continually characterize the network per traffic flow based on link state data of the virtual links received from a set of the VMs, wherein the feedback control system determines based on the characterization a best route through the network, and controls routing of each traffic flow to at least one next node of the best route.
  • VMs virtual machines
  • Embodiments include a method comprising instantiating a plurality of virtual routers (VRs) at each node of a plurality of nodes that form a network.
  • Each VR is coupled to the network and to a tenant of a plurality of tenants of the node.
  • the network comprises a plurality of virtual links in an overlay network provisioned over an underlay network including servers of a public network.
  • the method comprises configuring at least one VR to include a feedback control system comprising at least one objective function that characterizes the network.
  • the method comprises configuring the at least one VR to receive link state data of a set of virtual links of the plurality of virtual links, and control routing of a tenant traffic flow of each tenant according to a best route of the network determined by the at least one objective function using the link state data.
  • Embodiments include a method comprising: instantiating a plurality of virtual routers (VRs) at each node of a plurality of nodes that form a network, wherein each VR is coupled to the network and to a tenant of a plurality of tenants of the node, wherein the network comprises a plurality of virtual links in an overlay network provisioned over an underlay network including servers of a public network; configuring at least one VR to include a feedback control system comprising at least one objective function that characterizes the network; and configuring the at least one VR to receive link state data of a set of virtual links of the plurality of virtual links, and control routing of a tenant traffic flow of each tenant according to a best route of the network determined by the at least one objective function using the link state data.
  • VRs virtual routers
  • the method comprises configuring each node to include a plurality of virtual machines (VMs), wherein each VM includes a VR of the plurality of VRs and corresponds to the tenant.
  • VMs virtual machines
  • the method comprises configuring each VM to isolate at least one of a control plane and a data plane of each tenant from each other tenant of the plurality of tenants.
  • the method comprises configuring the control of the routing of the tenant traffic flow to include routing the tenant traffic flow from an ingress note to an egress node of the plurality of nodes.
  • the method comprises configuring the control of the routing of the tenant traffic to include each VR separately controlling routing of each tenant traffic flow to at least one next node of the best route.
  • the method comprises configuring the plurality of virtual links as a component of the overlay network that utilizes the underlay network for delivery of the tenant traffic flow.
  • the method comprises configuring each VR to form in the network the set of virtual links corresponding to the tenant, and configuring the set of virtual links to form a private tenant network corresponding to the tenant.
  • the method comprises configuring the plurality of virtual links to include a plurality of single-hop virtual links coupled between each node of the plurality of nodes.
  • the method comprises configuring the plurality of virtual links to include a plurality of sets of virtual links, wherein each set of virtual links forms a private tenant network of a corresponding tenant of the plurality of tenants.
  • the method comprises configuring the network to include a plurality of private tenant networks corresponding to the plurality of tenants, wherein each private tenant network is isolated from each other private tenant network of the plurality of private tenant networks.
  • the method comprises configuring the plurality of private tenant networks to maintain separation of multi-tenant traffic flows throughout the network.
  • the method comprises configuring each private tenant network with a tenant configuration of a corresponding tenant to control routing of tenant traffic flows of the tenant.
  • the method comprises configuring the tenant configuration to include traffic classification data, route data, and bandwidth.
  • the method comprises configuring each VR to include a plurality of routing control algorithms representing a plurality of routing behaviors.
  • the method comprises configuring each routing control algorithm to determine at least one path through the network for routing the tenant traffic flow from an ingress node of the plurality of nodes to an egress node of the plurality of nodes.
  • the method comprises configuring each routing behavior to correspond to a traffic classification of the tenant traffic flow.
  • the method comprises configuring each routing behavior as defined by an objective function of a plurality of objective functions, wherein the plurality of objective functions include the at least one objective function.
  • the method comprises configuring the VR to apply a corresponding objective function to the link state data and generate a link weight for each link of the set of links.
  • the method comprises configuring the VR to determine the best route of the tenant traffic flow according to link weights of the set of links.
  • the method comprises configuring the control of the routing of the tenant traffic flow to include adapting the at least one route in response to changes in the link state data as processed by the corresponding objective function.
  • the method comprises configuring the VR to periodically receive link state updates that include updated link state data of the set of virtual links.
  • the method comprises configuring the adapting of the at least one route to include applying the corresponding objective function to the updated link state data.
  • the method comprises configuring the VR to apply the corresponding objective function to the updated link state data and generate an updated link weight for each link of the set of links.
  • the method comprises configuring the VR to determine an updated best route of the tenant traffic flow according to updated link weights of the set of links.
  • the method comprises configuring each VR of a set of VRs to include the feedback control system comprising the at least one objective function that characterizes the network.
  • the method comprises configuring each VR of the plurality of VRs to include the feedback control system comprising the at least one objective function that characterizes the network.
  • the method comprises configuring the plurality of routing behaviors to include routing a tenant traffic flow via multiple paths of the network.
  • the method comprises configuring the plurality of routing behaviors to include routing a tenant traffic flow directly via a shortest path of the network.
  • the method comprises configuring the plurality of routing behaviors to include routing a tenant traffic flow on a path and maintaining the tenant traffic flow on the path until detection of an network event.
  • the network event includes at least one of a network topology change and a variation in the link state data exceeding a pre-specified threshold.
  • the method comprises configuring the best route to include at least one lowest cost path based on the link state data.
  • the method comprises configuring the link state data of each link to represent at least one link metric of the link.
  • the method comprises configuring the at least one link metric to include at least one of latency, jitter, packet loss, throughput, utilization, link state, and link status.
  • the method comprises configuring each VR to maintain configuration data for the corresponding tenant, and to use the configuration data in the control of the routing of the tenant traffic flow.
  • the method comprises configuring the configuration data to include traffic class configuration data.
  • the method comprises configuring the traffic class configuration data to identify traffic classes, and configures MCN behavior corresponding to each traffic class.
  • the method comprises configuring the configuration data to include route configuration data.
  • the method comprises configuring the route configuration data to include data of a service that is a recipient of the tenant traffic flow.
  • the method comprises configuring each VR to maintain topology data including a logical view of the overlay network for the corresponding tenant, and to use the topology data in the control of the routing of the tenant traffic flow.
  • the method comprises configuring each VM to include a monitoring agent coupled to the VR, and configuring the monitoring agent to collect data representing the link state data of the set of virtual links of the overlay network.
  • the method comprises configuring the data representing the link state data of the set of virtual links to include at least one link metric of the set of virtual links.
  • the method comprises configuring the at least one link metric to include at least one of latency, jitter, packet loss, throughput, utilization, link state, and link status.
  • the method comprises configuring each monitoring agent to collect the at least one link metric from at least one of a plurality of monitoring agents and a plurality of VRs of the plurality of VMs.
  • the method comprises configuring the VR to configure the set of virtual links for use by the monitoring agent.
  • the method comprises configuring each monitoring agent to collect the at least one link metric using probe signals exchanged with others of the plurality of VMs.
  • the method comprises configuring each VM to send the at least one link metric to the monitoring agent transmitting the probe signals in response to receipt of the probe signals.
  • the method comprises configuring the monitoring agent to generate the link state data of the set of virtual links by processing the at least one link metric.
  • the method comprises configuring the VR to receive from the monitoring agent the link state data of the set of virtual links.
  • the method comprises configuring each VR to receive the link state data of others of the plurality of links from others of the plurality of VRs.
  • the method comprises configuring each VM to include a virtual gateway coupled to the corresponding tenant and the corresponding VR, and configuring the virtual gateway to control tenant traffic flows incoming to the VM from the corresponding tenant.
  • the method comprises configuring the virtual gateway to couple to the monitoring agent.
  • the method comprises configuring the VR to generate at least one set of flow rules configured to control the routing of the tenant traffic flow through the overlay network.
  • the method comprises configuring the at least one set of flow rules to correspond to the at least one objective function.
  • the method comprises configuring the virtual gateway to attract tenant traffic flows of the corresponding tenant.
  • the method comprises configuring the virtual gateway to reject traffic flows arriving from sources other than the corresponding tenant.
  • the method comprises configuring each VM to include a set of public IP addresses dedicated to the corresponding tenant, wherein the corresponding tenant accesses the virtual gateway of the VM using the set of public IP addresses.
  • the method comprises configuring at least one virtual switch to couple to the VR and the virtual gateway of each VM.
  • the method comprises configuring the at least one virtual switch to include a set of routing tables representing the at least one set of flow rules.
  • the method comprises configuring the set of routing tables to manage the control of the routing of the tenant traffic flow through the network.
  • the method comprises configuring the at least one virtual switch to transfer the tenant traffic flow between the virtual gateway and the VR.
  • the method comprises configuring at least one of the virtual gateway, the VR, and the at least one virtual switch to form the set of virtual links.
  • the method comprises configuring an aggregator to couple to the at least one virtual switch.
  • the method comprises configuring the aggregator to route via the set of virtual links the tenant traffic flow received at the virtual gateway from the corresponding tenant.
  • the method comprises configuring the aggregator to route to the corresponding tenant the tenant traffic flow received at the node via the network.
  • the method comprises configuring the aggregator to route the tenant traffic flow arriving at the aggregator via the network to the corresponding tenant via at least one of the corresponding VR and the virtual gateway.
  • the method comprises configuring the virtual gateway to route the tenant traffic flow arriving at the aggregator to the tenant via a coupling over a public network.
  • the method comprises configuring each node to include an aggregator coupled to the at least one virtual switch and the network.
  • the method comprises configuring the aggregator to route via the network the tenant traffic flows of the plurality of tenants corresponding to the node.
  • the method comprises configuring each node to include a hypervisor, and configuring the hypervisor as an operating system of the plurality of VMs of the node.
  • the method comprises configuring the hypervisor to include the at least one virtual switch.
  • the method comprises configuring the hypervisor to include the aggregator.
  • the method comprises configuring a provisioner to couple to the plurality of VMs of the plurality of nodes, and to control provisioning of at least one of the overlay network and the underlay network.
  • the method comprises configuring the provisioner to couple to a queue comprising at least one pre-provisioned network, and configuring the control of the provisioning of the underlay network to include use of a pre-provisioned network of the queue as the underlay network.
  • the method comprises configuring the provisioner to control configuration of the plurality of VMs of the plurality of nodes.
  • the method comprises configuring the provisioner to control configuration of components of each VM of the plurality of VMs using a tenant configuration of the corresponding tenant.
  • the method comprises configuring the provisioner to generate routes
  • the method comprises configuring the provisioner to maintain network data of at least one of the overlay network and the underlay network, wherein the network data includes data representing the overlay network, the underlay network, route configurations, topology data of the network including the plurality of virtual links, and tenant configurations of the plurality of tenants.
  • the method comprises configuring a web application to couple to the provisioner, and to generate a user interface configured to generate for presentation prompts for data representing the tenant configuration, and to receive data input of the tenant.
  • the method comprises configuring the web application to maintain link state data of the plurality of virtual links, and link metrics represented by the link state data.
  • the method comprises configuring the web application to include an alerts engine configured to generate and manage alerts and notifications, wherein the alerts and notifications correspond to at least one of the link state data and the link metrics.
  • Embodiments include a system comprising a plurality of nodes configured to form a network comprising a plurality of virtual links in an overlay network provisioned over an underlay network including servers of a public network.
  • the system includes a plurality of virtual routers (VRs) at each node.
  • Each VR is coupled to the network and to a tenant of a plurality of tenants of the node.
  • At least one VR is configured to receive network data of a set of virtual links in real time during operation of the network, and determine and dynamically adapt an optimal route through the network using the network data.
  • the VR is configured to control routing of traffic flows through the network according to the optimal route, obviating routing based on pre-assigned link weights.
  • Embodiments include a system comprising: a plurality of nodes configured to form a network comprising a plurality of virtual links in an overlay network provisioned over an underlay network including servers of a public network; and a plurality of virtual routers (VRs) at each node, wherein each VR is coupled to the network and to a tenant of a plurality of tenants of the node, wherein at least one VR is configured to receive network data of a set of virtual links in real time during operation of the network, and determine and dynamically adapt an optimal route through the network using the network data, wherein the at least one VR is configured to control routing of traffic flows through the network according to the optimal route, obviating routing based on pre-assigned link weights.
  • Each VR is configured to form in the network the set of virtual links to correspond to the tenant, wherein the set of virtual links is a component of the overlay network and utilizes the underlay network for delivery of a tenant traffic flow of the tenant.
  • the at least one VR includes at least one objective function.
  • the VR is configured to characterize the network by applying the at least one objective function to the network data during each iteration of a plurality of iterations, wherein the optimal route is determined by minimizing the at least one objective function using the network data.
  • the VR is configured to use the network data to adaptively characterize the network, and iteratively determine the optimal route based on the adaptive
  • the network data includes link state data, wherein the characterization of the network comprises recognizing changes in the link state data based on feedback of the link state data from others of the plurality of VRs, and adapting the optimal route in response to the changes.
  • the link state data of each link represents at least one link metric of the link, wherein the at least one link metric includes at least one of latency, jitter, packet loss, throughput, utilization, link state, and link status.
  • the at least one objective function and the corresponding at least one link metric is configured to control quality of service (QoS) of the network, wherein the optimal route is configured to provide the QoS.
  • QoS quality of service
  • the network data is received in real time during each iteration.
  • An output of the objective function at each iteration adapts the optimal route through the network for the iteration.
  • An output of the objective function at each iteration comprises link weights of the set of virtual links.
  • the VR is configured to assign the link weights to the set of virtual links, and control routing of data traffic via the optimal route based on the link weights.
  • the control of the routing of the tenant traffic comprises each VR separately controlling routing of each tenant traffic flow to at least one next node of the optimal route.
  • the set of virtual links forms a private tenant network of the tenant, wherein the private tenant network is isolated from each other private tenant network corresponding to each other VR.
  • the private tenant network is configured with a tenant configuration of the tenant to control routing of tenant traffic flows of the tenant, wherein the tenant configuration includes traffic classification data, route data, and bandwidth.
  • the private tenant network includes a tenant control plane and a tenant data plane.
  • the VR is a component of the tenant control plane, wherein the tenant control plane is isolated from others of a plurality of control planes corresponding to other tenants of the plurality of tenants.
  • the tenant data plane is isolated from others of a plurality of data planes corresponding to other tenants of the plurality of tenants.
  • control plane is separate and distinct from the data plane, wherein each of the control plane and the data plane comprises at least one of software and hardware.
  • Each VR comprises a plurality of routing control algorithms representing a plurality of routing behaviors, wherein each routing behavior corresponds to a traffic classification of the tenant traffic flow.
  • Each routing control algorithm is configured to determine at least one path through the network for routing the tenant traffic flow from an ingress node of the plurality of nodes to an egress node of the plurality of nodes.
  • Each routing behavior is defined by an objective function of a plurality of objective functions, wherein the plurality of objective functions include the at least one objective function.
  • the VR is configured to apply a corresponding objective function to the network data and generate a link weight for each link of the set of links.
  • the VR is configured to determine the best route of the tenant traffic flow according to link weights of the set of links.
  • the control of the routing of the tenant traffic flow comprises continually adapting the at least one route in response to changes in an output of the corresponding objective function resulting from changes in the network data.
  • the VR is configured to periodically receive link state updates that include updated link state data of the set of virtual links.
  • the continually adapting of the at least one route comprises applying the corresponding objective function to the updated link state data.
  • the VR is configured to apply the corresponding objective function to the updated link state data and generate an updated link weight for each link of the set of links, and to determine an updated optimal route of the tenant traffic flow according to updated link weights of the set of links.
  • the plurality of routing behaviors includes routing a tenant traffic flow via multiple paths of the network.
  • the plurality of routing behaviors includes routing a tenant traffic flow directly via a shortest path of the network.
  • the plurality of routing behaviors includes routing a tenant traffic flow on a path and maintaining the tenant traffic flow on the path until detection of an network event.
  • the network event includes at least one of a network topology change and a variation in the link state data exceeding a pre-specified threshold.
  • the optimal route includes at least one lowest cost path based on the link state data.
  • Each VR is configured to maintain configuration data for the corresponding tenant, and to use the configuration data in the control of the routing of the tenant traffic flow.
  • the configuration data includes traffic class configuration data, wherein the traffic class configuration data identifies traffic classes, and configures behavior of the network corresponding to each traffic class.
  • the configuration data includes route configuration data, wherein the route configuration data includes data of a destination of the tenant traffic flow.
  • each VR is configured to maintain topology data including a logical view of the overlay network for the corresponding tenant, and to use the topology data in the control of the routing of the tenant traffic flow.
  • the at least one VR includes a single VR at a single node of the network.
  • the at least one VR includes a plurality of VRs at one or more nodes of the network.
  • Each VR is configured to asynchronously receive the network data relative to any other VR of the plurality of VRs.
  • the each VR is configured to asynchronously determine and adapt an optimal route relative to any other VR of the plurality of VRs.
  • the control of the routing comprises controlling routing of a traffic flow to a next node of the optimal route via a single path.

Abstract

L'invention concerne un système comprenant des nœuds configurés pour former un réseau comprenant des liaisons virtuelles dans un réseau superposé approvisionné sur un réseau sous-jacent. Le système comprend au moins une machine virtuelle (VM) au niveau de chaque nœud. La VM est couplée au réseau et à un locataire du nœud. La VM comprend des algorithmes de routage représentant des comportements de routage. Au moins un algorithme de routage est configuré pour utiliser des données de rétroaction d'un ensemble de liaisons virtuelles pour déterminer et adapter en continu une route optimale à travers le réseau. La VM est configurée pour commander le routage de flux de trafic en fonction de l'itinéraire optimal.
PCT/US2019/042261 2018-07-18 2019-07-17 Réseau central défini par logiciel haute performance WO2020018704A1 (fr)

Priority Applications (1)

Application Number Priority Date Filing Date Title
EP19838906.6A EP3824603A4 (fr) 2018-07-18 2019-07-17 Réseau central défini par logiciel haute performance

Applications Claiming Priority (34)

Application Number Priority Date Filing Date Title
US201862700137P 2018-07-18 2018-07-18
US62/700,137 2018-07-18
US201862745548P 2018-10-15 2018-10-15
US62/745,548 2018-10-15
US16/164,457 US20200036624A1 (en) 2017-01-31 2018-10-18 High performance software-defined core network
US16/164,457 2018-10-18
US16/188,740 2018-11-13
US16/188,740 US20190238449A1 (en) 2017-01-31 2018-11-13 High performance software-defined core network
US16/189,735 2018-11-13
US16/189,735 US20190238450A1 (en) 2017-01-31 2018-11-13 High performance software-defined core network
US16/207,156 2018-12-02
US16/207,155 US20200296026A1 (en) 2017-01-31 2018-12-02 High performance software-defined core network
US16/207,155 2018-12-02
US16/207,156 US11252079B2 (en) 2017-01-31 2018-12-02 High performance software-defined core network
US16/227,949 US20190280962A1 (en) 2017-01-31 2018-12-20 High performance software-defined core network
US16/227,949 2018-12-20
US16/227,967 2018-12-20
US16/227,967 US20190280963A1 (en) 2017-01-31 2018-12-20 High performance software-defined core network
US16/231,527 US10992568B2 (en) 2017-01-31 2018-12-23 High performance software-defined core network
US16/231,532 US20200021515A1 (en) 2017-01-31 2018-12-23 High performance software-defined core network
US16/231,530 2018-12-23
US16/231,532 2018-12-23
US16/231,530 US20200021514A1 (en) 2017-01-31 2018-12-23 High performance software-defined core network
US16/231,529 2018-12-23
US16/231,527 2018-12-23
US16/231,529 US20190280964A1 (en) 2017-01-31 2018-12-23 High performance software-defined core network
US16/378,757 2019-04-09
US16/378,712 US20190372889A1 (en) 2017-01-31 2019-04-09 High performance software-defined core network
US16/378,712 2019-04-09
US16/378,689 US11121962B2 (en) 2017-01-31 2019-04-09 High performance software-defined core network
US16/378,689 2019-04-09
US16/378,771 2019-04-09
US16/378,771 US20200106696A1 (en) 2017-01-31 2019-04-09 High performance software-defined core network
US16/378,757 US20190372890A1 (en) 2017-01-31 2019-04-09 High performance software-defined core network

Publications (1)

Publication Number Publication Date
WO2020018704A1 true WO2020018704A1 (fr) 2020-01-23

Family

ID=69165102

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2019/042261 WO2020018704A1 (fr) 2018-07-18 2019-07-17 Réseau central défini par logiciel haute performance

Country Status (1)

Country Link
WO (1) WO2020018704A1 (fr)

Cited By (43)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111371675A (zh) * 2020-02-26 2020-07-03 腾讯云计算(北京)有限责任公司 智能寻址方法、装置、设备及其存储介质
US10938693B2 (en) 2017-06-22 2021-03-02 Nicira, Inc. Method and system of resiliency in cloud-delivered SD-WAN
US10959098B2 (en) 2017-10-02 2021-03-23 Vmware, Inc. Dynamically specifying multiple public cloud edge nodes to connect to an external multi-computer node
US10958479B2 (en) 2017-10-02 2021-03-23 Vmware, Inc. Selecting one node from several candidate nodes in several public clouds to establish a virtual network that spans the public clouds
US10992568B2 (en) 2017-01-31 2021-04-27 Vmware, Inc. High performance software-defined core network
US10992558B1 (en) 2017-11-06 2021-04-27 Vmware, Inc. Method and apparatus for distributed data network traffic optimization
US10999137B2 (en) 2019-08-27 2021-05-04 Vmware, Inc. Providing recommendations for implementing virtual networks
US10999100B2 (en) 2017-10-02 2021-05-04 Vmware, Inc. Identifying multiple nodes in a virtual network defined over a set of public clouds to connect to an external SAAS provider
US10999165B2 (en) 2017-10-02 2021-05-04 Vmware, Inc. Three tiers of SaaS providers for deploying compute and network infrastructure in the public cloud
US11044190B2 (en) 2019-10-28 2021-06-22 Vmware, Inc. Managing forwarding elements at edge nodes connected to a virtual network
US11050588B2 (en) 2013-07-10 2021-06-29 Nicira, Inc. Method and system of overlay flow control
US20210203550A1 (en) * 2019-12-31 2021-07-01 Vmware, Inc. Multi-site hybrid networks across cloud environments
US11089111B2 (en) 2017-10-02 2021-08-10 Vmware, Inc. Layer four optimization for a virtual network defined over public cloud
US11115480B2 (en) 2017-10-02 2021-09-07 Vmware, Inc. Layer four optimization for a virtual network defined over public cloud
US11121962B2 (en) 2017-01-31 2021-09-14 Vmware, Inc. High performance software-defined core network
US11212140B2 (en) 2013-07-10 2021-12-28 Nicira, Inc. Network-link method useful for a last-mile connectivity in an edge-gateway multipath system
US11223514B2 (en) 2017-11-09 2022-01-11 Nicira, Inc. Method and system of a dynamic high-availability mode based on current wide area network connectivity
US11245641B2 (en) 2020-07-02 2022-02-08 Vmware, Inc. Methods and apparatus for application aware hub clustering techniques for a hyper scale SD-WAN
US11252079B2 (en) 2017-01-31 2022-02-15 Vmware, Inc. High performance software-defined core network
US11290859B2 (en) * 2019-11-14 2022-03-29 Verizon Patent And Licensing Inc. Method and system for content distribution among MEC networks
US11349722B2 (en) 2017-02-11 2022-05-31 Nicira, Inc. Method and system of connecting to a multipath hub in a cluster
US11363124B2 (en) 2020-07-30 2022-06-14 Vmware, Inc. Zero copy socket splicing
US11374904B2 (en) 2015-04-13 2022-06-28 Nicira, Inc. Method and system of a cloud-based multipath routing protocol
US11375005B1 (en) 2021-07-24 2022-06-28 Vmware, Inc. High availability solutions for a secure access service edge application
US11381499B1 (en) 2021-05-03 2022-07-05 Vmware, Inc. Routing meshes for facilitating routing through an SD-WAN
US11394640B2 (en) 2019-12-12 2022-07-19 Vmware, Inc. Collecting and analyzing data regarding flows associated with DPI parameters
US11418997B2 (en) 2020-01-24 2022-08-16 Vmware, Inc. Using heart beats to monitor operational state of service classes of a QoS aware network link
WO2022174924A1 (fr) * 2021-02-22 2022-08-25 Huawei Technologies Co., Ltd. Entités et procédés d'équilibrage de charge prédictif
US11444872B2 (en) 2015-04-13 2022-09-13 Nicira, Inc. Method and system of application-aware routing with crowdsourcing
US11444865B2 (en) 2020-11-17 2022-09-13 Vmware, Inc. Autonomous distributed forwarding plane traceability based anomaly detection in application traffic for hyper-scale SD-WAN
US11489783B2 (en) 2019-12-12 2022-11-01 Vmware, Inc. Performing deep packet inspection in a software defined wide area network
US11489720B1 (en) 2021-06-18 2022-11-01 Vmware, Inc. Method and apparatus to evaluate resource elements and public clouds for deploying tenant deployable elements based on harvested performance metrics
US11575600B2 (en) 2020-11-24 2023-02-07 Vmware, Inc. Tunnel-less SD-WAN
US11601356B2 (en) 2020-12-29 2023-03-07 Vmware, Inc. Emulating packet flows to assess network links for SD-WAN
US11606286B2 (en) 2017-01-31 2023-03-14 Vmware, Inc. High performance software-defined core network
US11677720B2 (en) 2015-04-13 2023-06-13 Nicira, Inc. Method and system of establishing a virtual private network in a cloud service for branch networking
US11706126B2 (en) 2017-01-31 2023-07-18 Vmware, Inc. Method and apparatus for distributed data network traffic optimization
US11706127B2 (en) 2017-01-31 2023-07-18 Vmware, Inc. High performance software-defined core network
US11729065B2 (en) 2021-05-06 2023-08-15 Vmware, Inc. Methods for application defined virtual network service among multiple transport in SD-WAN
US11792127B2 (en) 2021-01-18 2023-10-17 Vmware, Inc. Network-aware load balancing
US11909815B2 (en) 2022-06-06 2024-02-20 VMware LLC Routing based on geolocation costs
US11943146B2 (en) 2021-10-01 2024-03-26 VMware LLC Traffic prioritization in SD-WAN
US11979325B2 (en) 2021-01-28 2024-05-07 VMware LLC Dynamic SD-WAN hub cluster scaling with machine learning

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010233126A (ja) 2009-03-30 2010-10-14 Nec Corp 経路選択方法及び経路選択システム並びにそれに用いるルータ
US20100290422A1 (en) 2007-10-03 2010-11-18 Virtela Communications, Inc. Virtualized application acceleration infrastructure
US20130286846A1 (en) * 2012-04-25 2013-10-31 Juniper Networks, Inc. Path weighted equal-cost multipath
US20140064283A1 (en) * 2012-08-28 2014-03-06 Florin S. Balus System and method providing distributed virtual routing and switching (dvrs)
US20150139238A1 (en) * 2013-11-18 2015-05-21 Telefonaktiebolaget L M Ericsson (Publ) Multi-tenant isolation in a cloud environment using software defined networking
US20150163152A1 (en) * 2013-12-06 2015-06-11 Algoblu Holdings Limited Performance-based routing in software-defined network (sdn)

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100290422A1 (en) 2007-10-03 2010-11-18 Virtela Communications, Inc. Virtualized application acceleration infrastructure
JP2010233126A (ja) 2009-03-30 2010-10-14 Nec Corp 経路選択方法及び経路選択システム並びにそれに用いるルータ
US20130286846A1 (en) * 2012-04-25 2013-10-31 Juniper Networks, Inc. Path weighted equal-cost multipath
US20140064283A1 (en) * 2012-08-28 2014-03-06 Florin S. Balus System and method providing distributed virtual routing and switching (dvrs)
US20150139238A1 (en) * 2013-11-18 2015-05-21 Telefonaktiebolaget L M Ericsson (Publ) Multi-tenant isolation in a cloud environment using software defined networking
US20150163152A1 (en) * 2013-12-06 2015-06-11 Algoblu Holdings Limited Performance-based routing in software-defined network (sdn)

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
FRANCOIS ET AL.: "Optimizing Secure SDN-enabled Inter-Data Centre Overlay Networks through Cognitive Routing", 2016 IEEE 24TH INTERNATIONAL SYMPOSIUM ON MODELING, ANALYSIS AND SIMULATION OF COMPUTER AND TELECOMMUNICATION SYSTEMS (MASCOTS, 19 September 2016 (2016-09-19), pages 283 - 288, XP033018506, Retrieved from the Internet <URL:https://ieeexplore.ieee.org/document/7774591> [retrieved on 20191119] *
See also references of EP3824603A4

Cited By (83)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11804988B2 (en) 2013-07-10 2023-10-31 Nicira, Inc. Method and system of overlay flow control
US11050588B2 (en) 2013-07-10 2021-06-29 Nicira, Inc. Method and system of overlay flow control
US11212140B2 (en) 2013-07-10 2021-12-28 Nicira, Inc. Network-link method useful for a last-mile connectivity in an edge-gateway multipath system
US11677720B2 (en) 2015-04-13 2023-06-13 Nicira, Inc. Method and system of establishing a virtual private network in a cloud service for branch networking
US11374904B2 (en) 2015-04-13 2022-06-28 Nicira, Inc. Method and system of a cloud-based multipath routing protocol
US11444872B2 (en) 2015-04-13 2022-09-13 Nicira, Inc. Method and system of application-aware routing with crowdsourcing
US10992568B2 (en) 2017-01-31 2021-04-27 Vmware, Inc. High performance software-defined core network
US11700196B2 (en) 2017-01-31 2023-07-11 Vmware, Inc. High performance software-defined core network
US11706126B2 (en) 2017-01-31 2023-07-18 Vmware, Inc. Method and apparatus for distributed data network traffic optimization
US11706127B2 (en) 2017-01-31 2023-07-18 Vmware, Inc. High performance software-defined core network
US11121962B2 (en) 2017-01-31 2021-09-14 Vmware, Inc. High performance software-defined core network
US11252079B2 (en) 2017-01-31 2022-02-15 Vmware, Inc. High performance software-defined core network
US11606286B2 (en) 2017-01-31 2023-03-14 Vmware, Inc. High performance software-defined core network
US11349722B2 (en) 2017-02-11 2022-05-31 Nicira, Inc. Method and system of connecting to a multipath hub in a cluster
US11533248B2 (en) 2017-06-22 2022-12-20 Nicira, Inc. Method and system of resiliency in cloud-delivered SD-WAN
US10938693B2 (en) 2017-06-22 2021-03-02 Nicira, Inc. Method and system of resiliency in cloud-delivered SD-WAN
US10958479B2 (en) 2017-10-02 2021-03-23 Vmware, Inc. Selecting one node from several candidate nodes in several public clouds to establish a virtual network that spans the public clouds
US11606225B2 (en) 2017-10-02 2023-03-14 Vmware, Inc. Identifying multiple nodes in a virtual network defined over a set of public clouds to connect to an external SAAS provider
US11894949B2 (en) 2017-10-02 2024-02-06 VMware LLC Identifying multiple nodes in a virtual network defined over a set of public clouds to connect to an external SaaS provider
US11102032B2 (en) 2017-10-02 2021-08-24 Vmware, Inc. Routing data message flow through multiple public clouds
US10959098B2 (en) 2017-10-02 2021-03-23 Vmware, Inc. Dynamically specifying multiple public cloud edge nodes to connect to an external multi-computer node
US11089111B2 (en) 2017-10-02 2021-08-10 Vmware, Inc. Layer four optimization for a virtual network defined over public cloud
US11005684B2 (en) 2017-10-02 2021-05-11 Vmware, Inc. Creating virtual networks spanning multiple public clouds
US10999165B2 (en) 2017-10-02 2021-05-04 Vmware, Inc. Three tiers of SaaS providers for deploying compute and network infrastructure in the public cloud
US11895194B2 (en) 2017-10-02 2024-02-06 VMware LLC Layer four optimization for a virtual network defined over public cloud
US11115480B2 (en) 2017-10-02 2021-09-07 Vmware, Inc. Layer four optimization for a virtual network defined over public cloud
US11516049B2 (en) 2017-10-02 2022-11-29 Vmware, Inc. Overlay network encapsulation to forward data message flows through multiple public cloud datacenters
US11855805B2 (en) 2017-10-02 2023-12-26 Vmware, Inc. Deploying firewall for virtual network defined over public cloud infrastructure
US10999100B2 (en) 2017-10-02 2021-05-04 Vmware, Inc. Identifying multiple nodes in a virtual network defined over a set of public clouds to connect to an external SAAS provider
US10992558B1 (en) 2017-11-06 2021-04-27 Vmware, Inc. Method and apparatus for distributed data network traffic optimization
US11223514B2 (en) 2017-11-09 2022-01-11 Nicira, Inc. Method and system of a dynamic high-availability mode based on current wide area network connectivity
US11902086B2 (en) 2017-11-09 2024-02-13 Nicira, Inc. Method and system of a dynamic high-availability mode based on current wide area network connectivity
US11323307B2 (en) 2017-11-09 2022-05-03 Nicira, Inc. Method and system of a dynamic high-availability mode based on current wide area network connectivity
US11212238B2 (en) 2019-08-27 2021-12-28 Vmware, Inc. Providing recommendations for implementing virtual networks
US11310170B2 (en) 2019-08-27 2022-04-19 Vmware, Inc. Configuring edge nodes outside of public clouds to use routes defined through the public clouds
US11831414B2 (en) 2019-08-27 2023-11-28 Vmware, Inc. Providing recommendations for implementing virtual networks
US11258728B2 (en) 2019-08-27 2022-02-22 Vmware, Inc. Providing measurements of public cloud connections
US10999137B2 (en) 2019-08-27 2021-05-04 Vmware, Inc. Providing recommendations for implementing virtual networks
US11018995B2 (en) 2019-08-27 2021-05-25 Vmware, Inc. Alleviating congestion in a virtual network deployed over public clouds for an entity
US11252105B2 (en) 2019-08-27 2022-02-15 Vmware, Inc. Identifying different SaaS optimal egress nodes for virtual networks of different entities
US11252106B2 (en) 2019-08-27 2022-02-15 Vmware, Inc. Alleviating congestion in a virtual network deployed over public clouds for an entity
US11606314B2 (en) 2019-08-27 2023-03-14 Vmware, Inc. Providing recommendations for implementing virtual networks
US11171885B2 (en) 2019-08-27 2021-11-09 Vmware, Inc. Providing recommendations for implementing virtual networks
US11153230B2 (en) 2019-08-27 2021-10-19 Vmware, Inc. Having a remote device use a shared virtual network to access a dedicated virtual network defined over public clouds
US11121985B2 (en) 2019-08-27 2021-09-14 Vmware, Inc. Defining different public cloud virtual networks for different entities based on different sets of measurements
US11611507B2 (en) 2019-10-28 2023-03-21 Vmware, Inc. Managing forwarding elements at edge nodes connected to a virtual network
US11044190B2 (en) 2019-10-28 2021-06-22 Vmware, Inc. Managing forwarding elements at edge nodes connected to a virtual network
US11290859B2 (en) * 2019-11-14 2022-03-29 Verizon Patent And Licensing Inc. Method and system for content distribution among MEC networks
US11489783B2 (en) 2019-12-12 2022-11-01 Vmware, Inc. Performing deep packet inspection in a software defined wide area network
US11394640B2 (en) 2019-12-12 2022-07-19 Vmware, Inc. Collecting and analyzing data regarding flows associated with DPI parameters
US11716286B2 (en) 2019-12-12 2023-08-01 Vmware, Inc. Collecting and analyzing data regarding flows associated with DPI parameters
US20210203550A1 (en) * 2019-12-31 2021-07-01 Vmware, Inc. Multi-site hybrid networks across cloud environments
US11743115B2 (en) 2019-12-31 2023-08-29 Vmware, Inc. Multi-site hybrid networks across cloud environments
US11546208B2 (en) * 2019-12-31 2023-01-03 Vmware, Inc. Multi-site hybrid networks across cloud environments
US11438789B2 (en) 2020-01-24 2022-09-06 Vmware, Inc. Computing and using different path quality metrics for different service classes
US11418997B2 (en) 2020-01-24 2022-08-16 Vmware, Inc. Using heart beats to monitor operational state of service classes of a QoS aware network link
US11722925B2 (en) 2020-01-24 2023-08-08 Vmware, Inc. Performing service class aware load balancing to distribute packets of a flow among multiple network links
US11689959B2 (en) 2020-01-24 2023-06-27 Vmware, Inc. Generating path usability state for different sub-paths offered by a network link
US11606712B2 (en) 2020-01-24 2023-03-14 Vmware, Inc. Dynamically assigning service classes for a QOS aware network link
CN111371675B (zh) * 2020-02-26 2022-03-29 腾讯云计算(北京)有限责任公司 智能寻址方法、装置、设备及其存储介质
CN111371675A (zh) * 2020-02-26 2020-07-03 腾讯云计算(北京)有限责任公司 智能寻址方法、装置、设备及其存储介质
US11245641B2 (en) 2020-07-02 2022-02-08 Vmware, Inc. Methods and apparatus for application aware hub clustering techniques for a hyper scale SD-WAN
US11477127B2 (en) 2020-07-02 2022-10-18 Vmware, Inc. Methods and apparatus for application aware hub clustering techniques for a hyper scale SD-WAN
US11363124B2 (en) 2020-07-30 2022-06-14 Vmware, Inc. Zero copy socket splicing
US11709710B2 (en) 2020-07-30 2023-07-25 Vmware, Inc. Memory allocator for I/O operations
US11444865B2 (en) 2020-11-17 2022-09-13 Vmware, Inc. Autonomous distributed forwarding plane traceability based anomaly detection in application traffic for hyper-scale SD-WAN
US11575591B2 (en) 2020-11-17 2023-02-07 Vmware, Inc. Autonomous distributed forwarding plane traceability based anomaly detection in application traffic for hyper-scale SD-WAN
US11575600B2 (en) 2020-11-24 2023-02-07 Vmware, Inc. Tunnel-less SD-WAN
US11601356B2 (en) 2020-12-29 2023-03-07 Vmware, Inc. Emulating packet flows to assess network links for SD-WAN
US11929903B2 (en) 2020-12-29 2024-03-12 VMware LLC Emulating packet flows to assess network links for SD-WAN
US11792127B2 (en) 2021-01-18 2023-10-17 Vmware, Inc. Network-aware load balancing
US11979325B2 (en) 2021-01-28 2024-05-07 VMware LLC Dynamic SD-WAN hub cluster scaling with machine learning
WO2022174924A1 (fr) * 2021-02-22 2022-08-25 Huawei Technologies Co., Ltd. Entités et procédés d'équilibrage de charge prédictif
US11388086B1 (en) 2021-05-03 2022-07-12 Vmware, Inc. On demand routing mesh for dynamically adjusting SD-WAN edge forwarding node roles to facilitate routing through an SD-WAN
US11637768B2 (en) 2021-05-03 2023-04-25 Vmware, Inc. On demand routing mesh for routing packets through SD-WAN edge forwarding nodes in an SD-WAN
US11582144B2 (en) 2021-05-03 2023-02-14 Vmware, Inc. Routing mesh to provide alternate routes through SD-WAN edge forwarding nodes based on degraded operational states of SD-WAN hubs
US11509571B1 (en) 2021-05-03 2022-11-22 Vmware, Inc. Cost-based routing mesh for facilitating routing through an SD-WAN
US11381499B1 (en) 2021-05-03 2022-07-05 Vmware, Inc. Routing meshes for facilitating routing through an SD-WAN
US11729065B2 (en) 2021-05-06 2023-08-15 Vmware, Inc. Methods for application defined virtual network service among multiple transport in SD-WAN
US11489720B1 (en) 2021-06-18 2022-11-01 Vmware, Inc. Method and apparatus to evaluate resource elements and public clouds for deploying tenant deployable elements based on harvested performance metrics
US11375005B1 (en) 2021-07-24 2022-06-28 Vmware, Inc. High availability solutions for a secure access service edge application
US11943146B2 (en) 2021-10-01 2024-03-26 VMware LLC Traffic prioritization in SD-WAN
US11909815B2 (en) 2022-06-06 2024-02-20 VMware LLC Routing based on geolocation costs

Similar Documents

Publication Publication Date Title
US11706127B2 (en) High performance software-defined core network
US11700196B2 (en) High performance software-defined core network
US11606286B2 (en) High performance software-defined core network
US11121962B2 (en) High performance software-defined core network
US11252079B2 (en) High performance software-defined core network
US20200106696A1 (en) High performance software-defined core network
US20200021515A1 (en) High performance software-defined core network
US20190372890A1 (en) High performance software-defined core network
US20200296026A1 (en) High performance software-defined core network
US20190372889A1 (en) High performance software-defined core network
US20190238449A1 (en) High performance software-defined core network
US20200021514A1 (en) High performance software-defined core network
US20190280962A1 (en) High performance software-defined core network
US20190280963A1 (en) High performance software-defined core network
US20190280964A1 (en) High performance software-defined core network
WO2020018704A1 (fr) Réseau central défini par logiciel haute performance
US20230006929A1 (en) Method and system of application-aware routing with crowdsourcing
US10805272B2 (en) Method and system of establishing a virtual private network in a cloud service for branch networking
US10742556B2 (en) Tactical traffic engineering based on segment routing policies
Mendiola et al. A survey on the contributions of software-defined networking to traffic engineering
US9985875B1 (en) Route signalling based resilient application overlay network
US20160080211A1 (en) Methods and systems for controller-based data forwarding rules without routing protocols
US10153964B2 (en) Network routing using dynamic virtual paths in an overlay network
US10567252B1 (en) Network connection service high availability evaluation for co-location facilities
Alotaibi et al. Multidomain sdn-based gateways and border gateway protocol

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 19838906

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2019838906

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2019838906

Country of ref document: EP

Effective date: 20210218