Quality of service (QoS) mechanisms are important in datacenters in order to guarantee contracted-for levels of performance. However, rate-limiting mechanisms are generally performed in hardware (e.g., at the network interface controller (NIC) level), which aggregates all tenants of a datacenter together. Traffic is typically tenant-independent at the hardware level, and therefore difficult to disaggregate.
Some embodiments of the invention provide a network system that implements QoS by rate limiting at a logical network entity. The logical network entity is virtualized over multiple transport nodes. The system monitors traffic loads of the multiple transport nodes of the logical network entity. The system allocates a local committed rate (CR) and a local burst size (BS) to each of the multiple transport nodes. The allocated local CR and the local BS are determined based on the CR and BS parameters of the logical network entity and based on the monitored traffic loads. Each transport node of the logical network entity in turn controls an amount of data being processed by the transport node based on a token bucket value that is computed based on the local CR and the local BS of the transport node.
In some embodiments, a central control plane (CCP) node of a logical network that includes the logical network entity specifies the QoS requirement in terms of the CR parameter and the BS parameter. The CCP node also monitors the traffic loads of the multiple transport nodes and allocates the local CR and the local BS to each of the transport nodes based on the CR and BS parameters of the logical network entity and the monitored traffic loads.
In some embodiments, the multiple transport nodes include one or more edge nodes that control network traffic to and from a network (N-S traffic). In some embodiments, the multiple transport nodes include one or more managed forwarding elements in the logical network. In some embodiments, the managed forwarding elements are implemented by virtualization software running in different host computing devices in multiple different public cloud datacenters, and the logical network may also span multiple public cloud datacenters.
In some embodiments, the CR and the BS of the logical network entity are determined according to a QoS policy of the logical network entity. In some embodiments, the CCP node maintains a QoS data structure of the logical network entity that includes the CR and the BS of the logical network entity. In some embodiments, the QoS data structure also includes the local CR and the local BS of each transport node.
In some embodiments, the CCP node allocates the CR and the BS evenly among the transport nodes prior to monitoring the traffic loads of the transport nodes. In some embodiments, the CCP node monitors the traffic load of the logical network entity by periodically collecting traffic load information from each transport node to obtain the traffic load distribution of the logical network.
In some embodiments, each transport node has a local token value that specifies a current amount of data that can be processed for the transport node. Each transport node controls the amount of data being processed by the transport node by (i) adding to the local token value of the transport node an amount of data allowed to be processed by the transport node during a monitoring interval based on the local CR (e.g., local CR multiplied by a monitoring time interval) and (ii) subtracting from the local token value of the transport node an amount of data already processed by the transport node. The amount of data allowed to be processed by the transport node (i.e., the local token value) is capped according to the local BS parameter.
The preceding Summary is intended to serve as a brief introduction to some embodiments of the invention. It is not meant to be an introduction or overview of all inventive subject matter disclosed in this document. The Detailed Description that follows and the Drawings that are referred to in the Detailed Description will further describe the embodiments described in the Summary as well as other embodiments. Accordingly, to understand all the embodiments described by this document, a full review of the Summary, Detailed Description, the Drawings, and the Claims is needed. Moreover, the claimed subject matters are not to be limited by the illustrative details in the Summary, the Detailed Description and the Drawings, but rather are to be defined by the appended claims, because the claimed subject matters can be embodied in other specific forms without departing from the spirit of the subject matters.
The novel features of the invention are set forth in the appended claims. However, for purposes of explanation, several embodiments of the invention are set forth in the following figures.
In the following detailed description of the invention, numerous details, examples, and embodiments of the invention are set forth and described. However, it will be clear and apparent to one skilled in the art that the invention is not limited to the embodiments set forth and that the invention may be practiced without some of the specific details and examples discussed.
Some embodiments of the invention provide a method for applying a quality of service (QoS) policy on a logical network entity. Such a logical network entity is realized on or virtualized over a set of transport nodes such as edges and hypervisors (and denoted as T1, . . . , Tn). The traffic that traverses through such a logical network entity is subject to a rate limiting process, and the traffic being processed by the different transport nodes (T1, . . . , Tn) of the logical network entity are rate limited according to the QoS policy being applied to the logical network entity. The transport nodes involved in implementing the logical network entity function jointly to provide such rate limiting functionality. For example, a QoS requirement may be defined for a distributed router in an overlay (logical) network, and the host machines used to implement the edges and hypervisors of the distributed router may jointly operate in the same QoS policy context as transport nodes of the logical network entity. In some embodiments, a rate-limited logical network entity may have transport nodes that are edges for handling N-S traffic of an overlay network. In some embodiments, a rate-limited logical network entity may have transport nodes that are hypervisors and edges for handling E-W traffic of an overlay network.
The provider logical router 110 is implemented by several MFEs 121-125, and each of the three router ports (Ports A, B, and C) of the provider logical router 110 spans at least some of the MFEs 121-125. In other words, each MFE 121-125 may implement logical or virtual ports that correspond to some of the router ports of the provider logical router 110. In the example illustrated, MFEs 121, 122, 123, and 125 each implement a virtual port that corresponds to Port A of the provider logical router 110.
A distributed logical router port can be a logical network entity upon which a QoS policy is applied. A distributed logical router port is a logical port that can be realized on different transport nodes as defined by the span of the distributed router. Accordingly, all transport nodes involved in implementing the distributed logical router port jointly operate on the QoS policy to enforce rate limiting across those nodes. In the example of
In some embodiments, a QoS policy is applied to the logical entity based on token-bucket-value-based rate limiting. Namely, the logical entity is permitted to process traffic only if a token bucket value of the logical entity indicates that the logical network entity has a sufficient budget to process additional data (e.g., when the token bucket value is non-zero or greater than a threshold.) This token bucket value is computed according to the QoS policy applied to the logical network entity. In some embodiments, the token bucket value is computed according to at least two parameters: a committed rate (CR) and a burst size (BS). In other words, the token bucket value of a logical network entity has a CR parameter and a BS parameter that are defined according to the QoS of the logical network entity. As the logical network entity is processing a data or traffic load, the amount of data being processed by the logical network entity is subtracted from the token bucket value, while the amount of data that the logical network entity is permitted to process during a time interval (i.e., the CR parameter multiplied by the time interval) is added to the token bucket value. This addition is limited by the BS parameter, which places a cap on the burst token value (such that the token value can never be set larger than the BS parameter). The subtraction is limited such that the token value does not drop below zero. The logical entity is permitted to process the traffic load only if the token bucket value indicates a sufficient budget (e.g., greater than zero or a threshold) for processing additional data.
In some embodiments, for transport nodes that are involved with (or are used to implement) the logical network entity, the CR and BS of the logical network entity may be distributed among the involved transport nodes such that each transport node is allocated a local CR and a local BS. Each transport node in turn updates its local token bucket value based on the transport node's allocated local CR and local BS.
The figure shows three transport nodes (TN1, TN2, and TN3) of a logical network entity updating their respective local token bucket value based on their respective local CR and BS parameters. As the transport nodes TN1, TN2, and TN3 process their respective traffic load, their respective local token bucket values decrease. The local token bucket value of each transport node is replenished periodically based on the transport node's local CR parameter, e.g., at time instances t1, t2, t3, t4, t5, t6, etc. For example, at time t5, the local bucket token value of TN1 is increased by CR1*(t5−t4) (i.e., the local CR parameter of TN1 multiplied by a time interval since t4, which is the last replenishment into the local bucket token value of TN1.) Moreover, the replenishment of the local token bucket value of each transport node is constrained by the local BS parameter of the transport node. For example, though at time instances t5 and t6 the local token bucket value of TN2 is replenished, the value is capped by BS2 (or BS parameter of TN2).
In some embodiments, a central appliance in the control plane of the network is used to coordinate all transport nodes (T1, . . . , Tn) to facilitate the rate-limiting operations. An example of such a control plane central appliance is a central control plane (CCP) node in a datacenter that runs VMware's NSX-T. In some embodiments, the CCP node controlling the rate-limiting operations of a logical network entity maintains a QoS data structure for the logical network entity. The QoS data structure stores the CR and BS of the logical network entity that are specified based on the QoS policy of the logical network entity. The QoS data structure also stores the allocated local CR and BS parameters of each transport node involved with the logical network entity. In some embodiments, the CCP node monitors the traffic load at the different transport nodes and makes adjustments to the allocation of local CR and BS parameters of the involved transport nodes based on traffic load data collected from the different transport nodes. Specifically, the CCP node periodically (e.g., at the end of every monitoring interval) collects traffic load distribution from the transport nodes, then computes and sends the local CR and the local BS for each transport node.
In some embodiments, at the beginning of the QoS-based rate-limiting operation, the logical network entity's token bucket (and its corresponding CR and BS) is evenly distributed among the involved transport nodes such that if there are n involved transport nodes, each transport node is assigned a local committed rate=CR/n and a local burst size=BS/n. Each transport node involved with the logical network entity then monitors the local traffic load of the transport node at run-time, as the traffic load is being rate limited by the QoS policy (in terms of bytes per second). After a certain monitoring interval, some or all of the involved transport nodes will have their allocated local CR and BS adjusted based on the monitored traffic load. Each transport node in turn reports its run-time monitored traffic load to the CCP node, and the CCP node makes adjustments to the allocated local CR and BS parameters of the transport nodes based on traffic loads of the different transport nodes that are reported or collected in this time interval.
Let R1, . . . , Rn respectively represent the traffic load at different transport nodes T1, . . . , Tn. In some embodiments, the adjusted local committed rate for a transport node i is calculated as CRi=CR*(Ri/(R1+ . . . +Rn)). Likewise, the adjusted local burst size for a transport node i is calculated as BSi=BS*(Ri/(R1+ . . . +Rn)). In other words, both the local committed rate and the local burst size are adjusted based on a percentage of the total traffic load of the logical network entity that is the traffic load of the transport node i. Hence the transport nodes are jointly providing the committed rate and burst size for the QoS token bucket of the logical network entity as a whole. The advantage of this solution is that the local token buckets adapt their capacity based on run-time traffic load distribution. When the traffic distribution is skewed towards certain transport nodes, the above adjustment mechanism allocates higher bucket capacity to those transport nodes.
In some embodiments, the CCP node is selected from a cluster of CCP nodes (usually a cluster of 3), and a sharding mechanism is applied across different QoS policies supported in the system (the NSX-T network) to load balance the tasks of coordinating transport nodes. In some embodiments, the logical network entity being rate limited according to a particular QoS policy is in a virtualized shard associated with the particular QoS policy, where different virtualized shards support different QoS policies or classes.
As illustrated, a CCP cluster includes CCP nodes 411, 412, and 413 that are sharing the task of coordinating transport nodes for implementing QoS policies in different logical network entities. The CCP node 411 is coordinating the transport nodes of a logical network entity 421 to implement a QoS policy 431 (QoS A in terms of committed rate and burst size). The CCP node 412 is coordinating transport nodes of a logical network entity 422 to implement a QoS policy 432 (QoS B) and also transport nodes of a logical network entity 423 to implement a QoS policy 433 (QoS C). The CCP node 413 is coordinating the transport nodes of a logical network entity 424 to implement a QoS policy 434 (QoS D).
For some embodiments,
The process 500 starts when the CCP node specifies (at 510) a quality of service (QoS) requirement in terms of a committed rate (CR) parameter and a burst size (BS) parameter. In some embodiments, the CR and the BS of the logical network entity are determined according to a QoS policy of the logical network entity. In some embodiments, the CCP node maintains a QoS data structure of the logical network entity that includes the CR and the BS of the logical network entity.
The CCP node allocates (at 520) the CR and the BS of the logical network entity evenly among the transport nodes of the logical network entity as the local CR and local BS of each transport node. The CCP node monitors (at 530) monitors traffic loads of the plurality of transport nodes of the logical network entity. In some embodiments, the CCP node allocates the CR and BS evenly among the transport nodes prior to monitoring the traffic loads of the transport nodes. In some embodiments, the QoS data structure also includes the local CR and the local BS of each transport node. In some embodiments, the CCP node monitors the traffic load of the logical network entity by periodically collecting traffic load information from each transport node to obtain the traffic load distribution of the logical network.
The CCP node allocates (at 540) a local CR and a local BS to each of the plurality of transport nodes. The allocated local CR and the local BS are determined based on the CR and BS parameters of the logical network entity and based on the monitored traffic loads. For example, in some embodiments, the CCP node adjusts the local CR and BS parameters of a transport node based on a percentage of the total traffic load of the logical network entity that is the traffic load of the transport node.
Each transport node of the logical network entity in turn controls an amount of data being processed by the transport node based on a token bucket value that is computed based on the local CR and the local BS of the transport node. Each transport node has a local token value that specifies a current amount of data that can be processed for the transport node, and each transport node controls the amount of data being processed by the transport node by (i) adding to the local token value of the transport node an amount of data allowed to be processed by the transport node during a monitoring interval based on the local CR (e.g., local CR multiplied by a monitoring time interval) and (ii) subtracting from the local token value of the transport node an amount of data already processed by the transport node. The amount of data allowed to be processed by the transport node (i.e., the local token value) is capped according to the local BS parameter.
As illustrated, the CCP node 600 implements a network interface 610, a traffic load monitor 620, a traffic load storage 630, a local CR and BS allocator 640, a QoS storage 650, and a logical network entity manager 660. In some embodiments, the modules 610-660 are modules of software instructions being executed by one or more processing units (e.g., a processor) of a computing device. In some embodiments, the modules 610-660 are modules of hardware circuits implemented by one or more integrated circuits (ICs) of an electronic apparatus. Though the modules 610-660 are illustrated as being separate modules, some of the modules 610-660 can be combined into a single module. For example, the QoS storage 650 and the traffic load storage 630 may be implemented by a same storage module.
The network interface 610 of the CCP node 600 sends data to and receives data from a physical network, through which the CCP node 600 communicates with host machines 690 that implements the logical network entity and its transport nodes. Among the data received by the network interface 610 are traffic load statistics from the various transport nodes, which is identified and collected by the traffic load monitor 620 and stored in the traffic load storage 630.
Based on the traffic load data of the different transport nodes stored in the traffic load storage 630, the local CR and BS allocator 640 assigns local CR and BS parameters to each of the transport nodes based on the CR and BS parameters of the logical network entity, e.g., by adjusting the local CR and BS parameters of a transport node based on a percentage of the total traffic load of the logical network entity that is the load of the transport node. In some embodiments, prior to the traffic load data being available in the traffic load storage 630 (e.g., prior to monitoring the transport nodes), the local CR and BS allocator 640 divides the CR and BS parameters of the logical network entity evenly among the transport nodes as their local CR and BS parameters.
The QoS storage 650 stores the QoS data structures of the logical network entity. The QoS data structure may include the QoS policy, the CR and BS parameters of the logical network entity, and the allocated local CR and BS parameters of the different transport nodes (that are computed by the local CR and BS allocator 640). The logical network entity manager 660 in turn retrieves the allocated local CR and BS parameters for different transport nodes from the QoS storage 650 and transmits the retrieved parameters to the host machine that implements the transport node.
In some embodiments, one or more transport nodes of the logical network entity may be implemented by a host machine that is running virtualization software, serving as a virtual network forwarding engine. Such a virtual network forwarding engine is also known as managed forwarding element (MFE), or hypervisors. Virtualization software allows a computing device to host a set of virtual machines (VMs) or data compute nodes (DCNs) as well as to perform packet-forwarding operations (including L2 switching and L3 routing operations). These computing devices are therefore also referred to as host machines. The packet forwarding operations of the virtualization software are managed and controlled by a set of central controllers, and therefore the virtualization software is also referred to as a managed software forwarding element (MSFE) in some embodiments. In some embodiments, the MSFE performs its packet forwarding operations for one or more logical forwarding elements as the virtualization software of the host machine operates local instantiations of the logical forwarding elements as physical forwarding elements. Some of these physical forwarding elements are managed physical routing elements (MPREs) for performing L3 routing operations for a logical routing element (LRE), some of these physical forwarding elements are managed physical switching elements (MPSEs) for performing L2 switching operations for a logical switching element (LSE).
As illustrated, the computing device 700 has access to a physical network 790 through a physical NIC (PNIC) 795. The host machine 700 also runs the virtualization software 705 and hosts VMs 711-714. The virtualization software 705 serves as the interface between the hosted VMs 711-714 and the physical NIC 795 (as well as other physical resources, such as processors and memory). Each of the VMs 711-714 includes a virtual NIC (VNIC) for accessing the network through the virtualization software 705. Each VNIC in a VM 711-714 is responsible for exchanging packets between the VM 711-714 and the virtualization software 705. In some embodiments, the VNICs are software abstractions of physical NICs implemented by virtual NIC emulators.
The virtualization software 705 manages the operations of the VMs 711-714, and includes several components for managing the access of the VMs 711-714 to the physical network 790 (by implementing the logical networks to which the VMs connect, in some embodiments). As illustrated, the virtualization software 705 includes several components, including a MPSE 720, a set of MPREs 730, a controller agent 740, a network data storage 745, a VTEP 750, and a set of uplink pipelines 770.
The VTEP (VXLAN tunnel endpoint) 750 allows the host machine 700 to serve as a tunnel endpoint for logical network traffic (e.g., VXLAN traffic). VXLAN is an overlay network encapsulation protocol. An overlay network created by VXLAN encapsulation is sometimes referred to as a VXLAN network, or simply VXLAN. When a VM 711-714 on the host machine 700 sends a data packet (e.g., an Ethernet frame) to another VM in the same VXLAN network but on a different host (e.g., other machines 780,) the VTEP 750 will encapsulate the data packet using the VXLAN network's VNI and network addresses of the VTEP 750, before sending the packet to the physical network 790. The packet is tunneled through the physical network (i.e., the encapsulation renders the underlying packet transparent to the intervening network elements) to the destination host. The VTEP at the destination host decapsulates the packet and forwards only the original inner data packet to the destination VM. In some embodiments, the VTEP module serves only as a controller interface for VXLAN encapsulation, while the encapsulation and decapsulation of VXLAN packets is accomplished at the uplink module 770.
The controller agent 740 receives control plane messages from a controller 760 (e.g., a CCP node) or a cluster of controllers. In some embodiments, these control plane messages include configuration data for configuring the various components of the virtualization software 705 (such as the MPSE 720 and the MPREs 730) and/or the virtual machines 711-9814. In the example illustrated in
In some embodiments, the controller agent 740 receives the local CR and BS parameters from the CCP node and uses the received parameters to update a token bucket value locally. The host machine 700 may host multiple transport nodes of one or more logical network entities so may have multiple different token bucket values. For a transport node of a particular logical network entity (e.g., a MFE hosted by the host machine), the controller agent 740 controls the amount of data being processed by the transport node by (i) adding to the local token value of the transport node an amount of data allowed to be processed by the transport node during a monitoring interval based on the local CR and (ii) subtracting from the local token value of the transport node an amount of data already processed by the transport node. The amount of data allowed to be processed by the transport node is capped according to the local BS parameter.
The network data storage 745 in some embodiments stores some of the data that are used and produced by the logical forwarding elements of the host machine 700 (logical forwarding elements such as the MPSE 720 and the MPRE 730). Such stored data in some embodiments include forwarding tables and routing tables, connection mappings, as well as packet traffic statistics. These stored data are accessible by the controller agent 740 in some embodiments and delivered to another computing device (e.g., CCP node 600.)
The MPSE 720 delivers network data to and from the physical NIC 795, which interfaces the physical network 790. The MPSE 720 also includes a number of virtual ports (vPorts) that communicatively interconnect the physical NIC 795 with the VMs 711-714, the MPREs 730, and the controller agent 740. Each virtual port is associated with a unique L2 MAC address, in some embodiments. The MPSE 720 performs L2 link layer packet forwarding between any two network elements that are connected to its virtual ports. The MPSE 720 also performs L2 link layer packet forwarding between any network element connected to any one of its virtual ports and a reachable L2 network element on the physical network 790 (e.g., another VM running on another host). In some embodiments, a MPSE is a local instantiation of a logical switching element (LSE) that operates across the different host machines and can perform L2 packet switching between VMs on a same host machine or on different host machines. In some embodiments, the MPSE performs the switching function of several LSEs according to the configuration of those logical switches.
The MPREs 730 perform L3 routing on data packets received from a virtual port on the MPSE 720. In some embodiments, this routing operation entails resolving a L3 IP address to a next-hop L2 MAC address and a next-hop VNI (i.e., the VNI of the next-hop's L2 segment). Each routed data packet is then sent back to the MPSE 720 to be forwarded to its destination according to the resolved L2 MAC address. This destination can be another VM connected to a virtual port on the MPSE 720, or a reachable L2 network element on the physical network 790 (e.g., another VM running on another host, a physical non-virtualized machine, etc.).
As mentioned, in some embodiments, a MPRE is a local instantiation of a logical routing element (LRE) that operates across the different host machines and can perform L3 packet forwarding between VMs on a same host machine or on different host machines. In some embodiments, a host machine may have multiple MPREs connected to a single MPSE, where each MPRE in the host machine implements a different LRE. MPREs and MPSEs are referred to as “physical” routing/switching elements in order to distinguish from “logical” routing/switching elements, even though MPREs and MPSEs are implemented in software in some embodiments. In some embodiments, a MPRE is referred to as a “software router” and a MPSE is referred to as a “software switch”. In some embodiments, LREs and LSEs are collectively referred to as logical forwarding elements (LFEs), while MPREs and MPSEs are collectively referred to as managed physical forwarding elements (MPFEs). Some of the logical resources (LRs) mentioned throughout this document are LREs or LSEs that have corresponding local MPREs or a local MPSE running in each host machine.
In some embodiments, the MPRE 730 includes one or more logical interfaces (LIFs) that each serve as an interface to a particular segment (L2 segment or VXLAN) of the network. In some embodiments, each LIF is addressable by its own IP address and serves as a default gateway or ARP proxy for network nodes (e.g., VMs) of its particular segment of the network. In some embodiments, all of the MPREs in the different host machines are addressable by a same “virtual” MAC address (or vMAC), while each MPRE is also assigned a “physical” MAC address (or pMAC) in order to indicate in which host machine the MPRE operates.
The uplink module 770 relays data between the MPSE 720 and the physical NIC 795. The uplink module 770 includes an egress chain and an ingress chain that each perform a number of operations. Some of these operations are pre-processing and/or post-processing operations for the MPRE 730.
As illustrated by
The MPSE 720 and the MPRE 730 make it possible for data packets to be forwarded amongst VMs 711-714 without being sent through the external physical network 790 (so long as the VMs connect to the same logical network, as different tenants' VMs will be isolated from each other). Specifically, the MPSE 720 performs the functions of the local logical switches by using the VNIs of the various L2 segments (i.e., their corresponding L2 logical switches) of the various logical networks. Likewise, the MPREs 730 perform the function of the logical routers by using the VNIs of those various L2 segments. Since each L2 segment/L2 switch has its own a unique VNI, the host machine 700 (and its virtualization software 705) is able to direct packets of different logical networks to their correct destinations and effectively segregate traffic of different logical networks from each other.
Many of the above-described features and applications are implemented as software processes that are specified as a set of instructions recorded on a computer-readable storage medium (also referred to as computer-readable medium). When these instructions are executed by one or more processing unit(s) (e.g., one or more processors, cores of processors, or other processing units), they cause the processing unit(s) to perform the actions indicated in the instructions. Examples of computer-readable media include, but are not limited to, CD-ROMs, flash drives, RAM chips, hard drives, EPROMs, etc. The computer-readable media does not include carrier waves and electronic signals passing wirelessly or over wired connections.
In this specification, the term “software” is meant to include firmware residing in read-only memory or applications stored in magnetic storage, which can be read into memory for processing by a processor. Also, in some embodiments, multiple software inventions can be implemented as sub-parts of a larger program while remaining distinct software inventions. In some embodiments, multiple software inventions can also be implemented as separate programs. Finally, any combination of separate programs that together implement a software invention described here is within the scope of the invention. In some embodiments, the software programs, when installed to operate on one or more electronic systems, define one or more specific machine implementations that execute and perform the operations of the software programs.
The bus 805 collectively represents all system, peripheral, and chipset buses that communicatively connect the numerous internal devices of the computer system 800. For instance, the bus 805 communicatively connects the processing unit(s) 810 with the read-only memory 830, the system memory 820, and the permanent storage device 835.
From these various memory units, the processing unit(s) 810 retrieve instructions to execute and data to process in order to execute the processes of the invention. The processing unit(s) 810 may be a single processor or a multi-core processor in different embodiments. The read-only-memory (ROM) 830 stores static data and instructions that are needed by the processing unit(s) 810 and other modules of the computer system 800. The permanent storage device 835, on the other hand, is a read-and-write memory device. This device 835 is a non-volatile memory unit that stores instructions and data even when the computer system 800 is off. Some embodiments of the invention use a mass-storage device (such as a magnetic or optical disk and its corresponding disk drive) as the permanent storage device 835.
Other embodiments use a removable storage device (such as a floppy disk, flash drive, etc.) as the permanent storage device 835. Like the permanent storage device 835, the system memory 820 is a read-and-write memory device. However, unlike storage device 835, the system memory 820 is a volatile read-and-write memory, such a random access memory. The system memory 820 stores some of the instructions and data that the processor needs at runtime. In some embodiments, the invention's processes are stored in the system memory 820, the permanent storage device 835, and/or the read-only memory 830. From these various memory units, the processing unit(s) 810 retrieve instructions to execute and data to process in order to execute the processes of some embodiments.
The bus 805 also connects to the input and output devices 840 and 845. The input devices 840 enable the user to communicate information and select commands to the computer system 800. The input devices 840 include alphanumeric keyboards and pointing devices (also called “cursor control devices”). The output devices 845 display images generated by the computer system 800. The output devices 845 include printers and display devices, such as cathode ray tubes (CRT) or liquid crystal displays (LCD). Some embodiments include devices such as a touchscreen that function as both input and output devices 840 and 845.
Finally, as shown in
Some embodiments include electronic components, such as microprocessors, storage and memory that store computer program instructions in a machine-readable or computer-readable medium (alternatively referred to as computer-readable storage media, machine-readable media, or machine-readable storage media). Some examples of such computer-readable media include RAM, ROM, read-only compact discs (CD-ROM), recordable compact discs (CD-R), rewritable compact discs (CD-RW), read-only digital versatile discs (e.g., DVD-ROM, dual-layer DVD-ROM), a variety of recordable/rewritable DVDs (e.g., DVD-RAM, DVD-RW, DVD+RW, etc.), flash memory (e.g., SD cards, mini-SD cards, micro-SD cards, etc.), magnetic and/or solid state hard drives, read-only and recordable Blu-Ray® discs, ultra-density optical discs, any other optical or magnetic media, and floppy disks. The computer-readable media may store a computer program that is executable by at least one processing unit and includes sets of instructions for performing various operations. Examples of computer programs or computer code include machine code, such as is produced by a compiler, and files including higher-level code that are executed by a computer, an electronic component, or a microprocessor using an interpreter.
While the above discussion primarily refers to microprocessor or multi-core processors that execute software, some embodiments are performed by one or more integrated circuits, such as application-specific integrated circuits (ASICs) or field-programmable gate arrays (FPGAs). In some embodiments, such integrated circuits execute instructions that are stored on the circuit itself.
As used in this specification, the terms “computer”, “server”, “processor”, and “memory” all refer to electronic or other technological devices. These terms exclude people or groups of people. For the purposes of the specification, the terms display or displaying means displaying on an electronic device. As used in this specification, the terms “computer-readable medium,” “computer-readable media,” and “machine-readable medium” are entirely restricted to tangible, physical objects that store information in a form that is readable by a computer. These terms exclude any wireless signals, wired download signals, and any other ephemeral or transitory signals.
While the invention has been described with reference to numerous specific details, one of ordinary skill in the art will recognize that the invention can be embodied in other specific forms without departing from the spirit of the invention. Several embodiments described above include various pieces of data in the overlay encapsulation headers. One of ordinary skill will realize that other embodiments might not use the encapsulation headers to relay all of this data.
Also, several figures conceptually illustrate processes of some embodiments of the invention. In other embodiments, the specific operations of these processes may not be performed in the exact order shown and described in these figures. The specific operations may not be performed in one continuous series of operations, and different specific operations may be performed in different embodiments. Furthermore, the process could be implemented using several sub-processes, or as part of a larger macro process. Thus, one of ordinary skill in the art would understand that the invention is not to be limited by the foregoing illustrative details, but rather is to be defined by the appended claims.
This application is a continuation application of U.S. patent application Ser. No. 17/569,276, filed Jan. 5, 2022, now published as U.S. Patent Publication 2022/0393983. U.S. patent application Ser. No. 17/569,276 claims the benefit of U.S. Provisional Patent Application 63/208,394, filed Jun. 8, 2021. U.S. patent application Ser. No. 17/569,276, now published as U.S. Patent Publication 2022/0393983, is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
7516487 | Szeto et al. | Apr 2009 | B1 |
7734895 | Agarwal et al. | Jun 2010 | B1 |
8509068 | Begall et al. | Aug 2013 | B2 |
9378049 | Johnson | Jun 2016 | B1 |
9942144 | Ramalingam et al. | Apr 2018 | B1 |
10382329 | Thomas et al. | Aug 2019 | B1 |
10778721 | Holbrook et al. | Sep 2020 | B1 |
10785056 | Mathur et al. | Sep 2020 | B1 |
10833992 | Dickinson | Nov 2020 | B1 |
10880121 | Nirmala et al. | Dec 2020 | B1 |
10897420 | Pianigiani et al. | Jan 2021 | B1 |
11265292 | Leviseur | Mar 2022 | B1 |
11483246 | Wang et al. | Oct 2022 | B2 |
11539633 | Wang et al. | Dec 2022 | B2 |
11599395 | Wang et al. | Mar 2023 | B2 |
20030081546 | Agrawal et al. | May 2003 | A1 |
20030172145 | Nguyen | Sep 2003 | A1 |
20050047420 | Tanabe | Mar 2005 | A1 |
20050066166 | Chin et al. | Mar 2005 | A1 |
20050195964 | Hahn | Sep 2005 | A1 |
20050265376 | Chapman | Dec 2005 | A1 |
20070253439 | Iny | Nov 2007 | A1 |
20080222730 | Ford et al. | Sep 2008 | A1 |
20090016336 | LaVigne et al. | Jan 2009 | A1 |
20090119750 | Sembugamoorthy et al. | May 2009 | A1 |
20090129271 | Ramankutty et al. | May 2009 | A1 |
20090161682 | Johnson et al. | Jun 2009 | A1 |
20090300759 | Wang et al. | Dec 2009 | A1 |
20100135287 | Hosain et al. | Jun 2010 | A1 |
20110176418 | Gershinsky | Jul 2011 | A1 |
20120051218 | Mohandoss et al. | Mar 2012 | A1 |
20120081580 | Côtéet al. | Apr 2012 | A1 |
20130028228 | Nakayama | Jan 2013 | A1 |
20130058229 | Casado et al. | Mar 2013 | A1 |
20130125120 | Zhang et al. | May 2013 | A1 |
20130185436 | Carlin et al. | Jul 2013 | A1 |
20140052877 | Mao | Feb 2014 | A1 |
20140153422 | Nambiar et al. | Jun 2014 | A1 |
20140156720 | Janakiraman et al. | Jun 2014 | A1 |
20150016286 | Ganichev et al. | Jan 2015 | A1 |
20150016469 | Ganichev et al. | Jan 2015 | A1 |
20150113133 | Srinivas et al. | Apr 2015 | A1 |
20150244630 | Madem et al. | Aug 2015 | A1 |
20150256466 | Roitshtein | Sep 2015 | A1 |
20150263899 | Tubaltsev et al. | Sep 2015 | A1 |
20150271303 | Neginhal et al. | Sep 2015 | A1 |
20150281277 | May et al. | Oct 2015 | A1 |
20160014634 | Liu et al. | Jan 2016 | A1 |
20160057166 | Chesla | Feb 2016 | A1 |
20160080211 | Anand et al. | Mar 2016 | A1 |
20160105333 | Lenglet et al. | Apr 2016 | A1 |
20160164910 | Tang | Jun 2016 | A1 |
20160182255 | Liu et al. | Jun 2016 | A1 |
20160218918 | Chu et al. | Jul 2016 | A1 |
20160335129 | Behera | Nov 2016 | A1 |
20170118042 | Bhattacharya et al. | Apr 2017 | A1 |
20170149648 | Yang et al. | May 2017 | A1 |
20170317954 | Masurekar et al. | Nov 2017 | A1 |
20180048537 | Gaikwad | Feb 2018 | A1 |
20180091547 | Pierre | Mar 2018 | A1 |
20180157515 | Malloy et al. | Jun 2018 | A1 |
20180176181 | Fu et al. | Jun 2018 | A1 |
20180262599 | Firestone | Sep 2018 | A1 |
20180279161 | Chen et al. | Sep 2018 | A1 |
20180285151 | Wang et al. | Oct 2018 | A1 |
20180309640 | Nagarajan et al. | Oct 2018 | A1 |
20180359134 | Pech et al. | Dec 2018 | A1 |
20190007330 | Browne et al. | Jan 2019 | A1 |
20190014051 | Briscoe et al. | Jan 2019 | A1 |
20190044809 | Willis et al. | Feb 2019 | A1 |
20190081899 | Mundkur et al. | Mar 2019 | A1 |
20190108068 | Britkin et al. | Apr 2019 | A1 |
20190182367 | Kim et al. | Jun 2019 | A1 |
20190334868 | Tewari et al. | Oct 2019 | A1 |
20200278892 | Nainar et al. | Sep 2020 | A1 |
20200296139 | Fainberg et al. | Sep 2020 | A1 |
20200413283 | Shen et al. | Dec 2020 | A1 |
20210064429 | Stetter, Jr. et al. | Mar 2021 | A1 |
20210067489 | Jayawardena et al. | Mar 2021 | A1 |
20210119970 | Raphael et al. | Apr 2021 | A1 |
20210176168 | Eckert et al. | Jun 2021 | A1 |
20210218677 | Wang et al. | Jul 2021 | A1 |
20210227424 | Wang et al. | Jul 2021 | A1 |
20210255903 | Wang et al. | Aug 2021 | A1 |
20210297451 | Raphael et al. | Sep 2021 | A1 |
20210306354 | Raghuramu et al. | Sep 2021 | A1 |
20210399920 | Sundararajan et al. | Dec 2021 | A1 |
20210406255 | Raghuramu et al. | Dec 2021 | A1 |
20220070102 | Wang et al. | Mar 2022 | A1 |
20220158922 | Srivastava | May 2022 | A1 |
20220264360 | Chen | Aug 2022 | A1 |
20220393983 | Wang et al. | Dec 2022 | A1 |
20230041869 | Wang et al. | Feb 2023 | A1 |
20230130529 | Wang et al. | Apr 2023 | A1 |
20230168947 | Wang et al. | Jun 2023 | A1 |
20240031230 | Gaikwad | Jan 2024 | A1 |
Number | Date | Country |
---|---|---|
106059960 | Oct 2016 | CN |
109547502 | Mar 2019 | CN |
2015527 | Oct 2018 | EP |
Entry |
---|
Seddiki, M. Said, et al., “FlowQoS: QoS for the Rest of US,” HotSDN '14, Aug. 22, 2014, 2 pages, ACM, Chicago, IL, USA. |
Number | Date | Country | |
---|---|---|---|
20240015105 A1 | Jan 2024 | US |
Number | Date | Country | |
---|---|---|---|
63208394 | Jun 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17569276 | Jan 2022 | US |
Child | 18371454 | US |