To date, several solutions have been proposed for managing logical forwarding elements in virtualized computing environments. Some of these solutions use a cluster of controllers to manage the logical network elements. For some of these functionalities, these logical forwarding elements are implemented by physical forwarding elements (e.g., software or hardware switches) that are configured and managed by the controller cluster.
Some of the operations of these managed physical forwarding elements need data from the controllers to process packets or messages. These communications are typically out-of-band, control channel communications. Often, due to the large number of host computers that execute software forwarding elements, the controllers have control channel connections with a large number of host computers. Such large number of connections can tax the resources of any one controller, especially when the load is unevenly distributed between the controllers. Accordingly, there is a need for a novel scheme for distributing the control channel load on the controllers of a multi-controller network control system.
Some embodiments provide a novel method for distributing control-channel communication load between multiple controllers in a network control system. In some embodiments, the controllers manage physical forwarding elements that forward data between several computing devices (also called hosts or host computers), some or all of which execute one or more virtual machines (VMs). In some embodiments, some or all of managed physical forwarding elements are software forwarding elements that execute on host computers to implement different logical forwarding elements (e.g., logical switches, logical routers, etc.) for different virtual networks of different tenants, users, departments, etc. that use the same shared compute and networking resources. The controllers in some embodiments execute network control applications that manage the physical forwarding elements.
The method of some embodiments distributes a controller assignment list to the host computers. The host computers use this list to identify the controllers with which they need to interact to perform some of the forwarding operations of their associated logical forwarding elements. In some embodiments, agents executing on the host computers (1) review the controller assignment list to identify the appropriate controllers, and (2) establish control channel communications with these controllers to obtain the needed data for effectuating the forwarding operations of their associated physical forwarding elements. These agents in some embodiments are responsible for out-of-band control channel communication with the controllers.
To identify the appropriate controller for each logical forwarding element (LFE), the controller assignment list includes two parameters for each LFE. One parameter is an index value (called an index parameter) that is derivable from an identifier that identifies the LFE (called an LFE identifier). The other parameter is an identifier (called a controller identifier) that identifies a controller that is responsible for processing requests for the LFE. In some embodiments, the controller identifier is an address (e.g., IP address) of the controller, while in other embodiments, the controller identifier is a value from which the address of the controller can be obtained (e.g., through another table).
For each type of LFE managed by the network control system, the controllers and the hosts use the same index generation process to generate the index values for different LFEs of the same type. In some embodiments, the controllers and the hosts use the same index generation process for different types of LFEs, while in other embodiments they use different index generation process for different types of LFEs. In some embodiments, one controller (i.e., a master controller) creates the controller list by (1) assigning each LFE to a controller, (2) using the appropriate index generation process or processes to generate the index values from the LFE identifiers, and (3) creating for each LFE a record in the controller list that specifies the LFE's assigned controller in terms of the controller's identifier and the LFE's derived index value. In some embodiments, the controller set (e.g., the master controller) does not explicitly generate the index values from the LFE identifiers (the LFEIs), but rather assigns a defined range of index values to the different controllers, as further described below.
An agent of a host can identify the controller for a particular LFE executing on the host by (1) using the index generation process for the correct LFE type to generate an index value and (2) using the generated index value to retrieve the controller identifier from the controller assignment list. The retrieved controller identifier specifies the controller for the agent to connect in order to obtain necessary data for processing requests associated with the particular LFE's operations. As mentioned above, the controller identifier in some embodiments specifies the address of the controller, while in other embodiments this identifier is used to retrieve the address of the controller (e.g., through another table). In some embodiments, an agent identifies a controller for an LFE while it is setting up the LFE on the host, or upon receiving a new controller assignment list from the controller. In some of these embodiments, the agent establishes a connection (e.g., a TCP/IP session) with the LFE's controller upon identifying the controller, so that it can use this connection to process subsequent LFE operations that need the controller's input.
The index generation process of some embodiments is a hash operation that maps identifiers for different types of LFEs to the same range of index values. For instance, in some embodiments, the hash operation ends with a modulo operation that expresses the final hashed index value in terms of an integer that is the remainder value of the operation. Using this approach, the controller set (e.g., the master controller) assigns the controllers to different ranges of the possible hash value. This assignment is done in a manner to achieve a desired load balancing across the controllers. For instance, in some embodiments, this assignment is uniform or approximately uniform in terms of the number of controllers and the number of LFEs. In some of these embodiments, the controller cluster (e.g., the master controller) assigns equal sized hash value ranges to different controllers as its distribution scheme distributes the LFE identifiers uniformly across the LFEI range in order to ensure even distribution across the hash value ranges. In other embodiments, this assignment is uniform or approximately uniform in terms of data that is collected dynamically, such as data traffic load for each LFE, the number of VMs for each LFE, etc.
Using a hash/modulo process allows the distribution method of some embodiments to assign a defined range of index values to the different controllers without requiring the controller cluster (e.g., the master controller) to explicitly compute an index value for each LFE. The host agents in these embodiments use the hashing process to generate an index value that identifies a controller in the controller assignment list. In some embodiments, the same hash/modulo process is used for different LFE types, as mentioned above. In other embodiments, different hash/modulo processes are used for different LFE types (e.g., in order to allow different LFE types to different hash value ranges).
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 and the Drawings is needed. Moreover, the claimed subject matters are not to be limited by the illustrative details in the Summary, Detailed Description and the Drawing.
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 provide a multi-controller network control system with a novel scheme for distributing control-channel communication load between the different controllers. Under this scheme, a list of controller assignments is distributed to computing devices that need to have control-channel communication with the controllers in order to effectuate forwarding operations of the forwarding elements that are implemented by the computing devices. The controller assignment list stores the identity of the controllers for the different forwarding elements based on index values that are derivable from identifiers that identify the forwarding elements. The computing devices retrieve the controller identifiers from the controller assignment list by generating index values from the forwarding element identifiers and using these index values to identify the correct records in the controller assignment list.
In the example illustrated in
In the virtualization field, some refer to software forwarding elements (such as PFEs 112-118) as virtual switches as these are software elements. However, in this document, the software forwarding elements are referred to as physical forwarding elements, in order to distinguish them from logical forwarding elements, which are logical constructs that are not tied to the physical world. In other words, the software switching elements are referred to as PFEs because they exist and operate in the physical world, whereas logical forwarding elements are simply a logical representation of a forwarding element that is presented to a user. Examples of logical forwarding elements include logical switches, logical routers, etc.
The controller cluster 101 manages the physical forwarding elements 112-118 to implement different logical forwarding elements (LFEs) for different virtual networks of different tenants, users, departments, etc. that use the same shared compute and networking resources. For instance, as shown in
In some embodiments, a logical switch provides an L2 connectivity to VMs connected to the logical switch. The logical L2 connectivity may be VXLAN backed (and can also be implemented with any other overlay technologies like NVGRE, STT, etc.). When the logical L2 switch is implemented with VXLAN, VXLAN Network Identifier (VNI) may be used as the identifier of the LS.
To manage the physical forwarding elements, the controllers in some embodiments execute network control applications that direct the management of these elements. In some embodiments, the majority of the LFE operations are performed by the PFEs according to the configuration of these PFEs that is specified by the controller cluster 101. However, some of the LFE operations require real-time input from the controller clusters. Examples of such operations that require real-time input in some embodiments include ARP broadcasts, DHCP broadcasts, etc. These examples are described in concurrently filed U.S. patent application Ser. No. 14/070,360, entitled “Proxy Methods for Suppressing Broadcast Traffic in a Network,” now issued as U.S. Pat. No. 9,548,965.
For such real-time input, each host has (1) a proxy 154 in the datapath between the VM and the PFE, and (2) an agent 150. The proxies 154 are used to capture certain requests (e.g., ARP requests) from the VMs and re-route these requests to the agents, so that the agents can communicate with the controllers and obtain data needed to process such requests. In some embodiments, the proxies are part of virtual network interface cards (VNICs) of the VMs or are part of PFEs (e.g., the virtual ports of the PFEs). In some of these embodiments, the proxies can be viewed as function calls to the agents.
In some embodiments, each agent 150 maintains one or more control channel communication sessions (e.g., TCP/IP sessions) with one or more controllers, in order to process such requests.
Different controllers are responsible for processing requests for different LFEs. Accordingly, in some embodiments, each agent establishes out-of-band control channel communication connection (e.g., a TCP/IP connection) with each controller that is responsible for each LFE that is implemented or may be implemented with the agent's associated PFE. Several examples for establishing and eliminating such connections are further described below. In some embodiments, an agent can establish multiple different connections with the same controller for multiple different LFEs handled by the agent, while in other embodiments, an agent establishes only on connection with a controller for all LFEs handled by the agent.
The controller cluster 101 of some embodiments distributes a controller assignment list 160 to the host computers. The host computers use this list to identify the controllers with which they need to interact to perform some of the forwarding operations of the LFEs that their PFEs implement. In some embodiments, the agents 150 (1) review the controller assignment list to identify the appropriate controllers for the different LFEs, and (2) establish control channel communications with these controllers to obtain the data needed for effectuating the forwarding operations of their associated LFEs.
To identify the appropriate controller for each LFE, the controller assignment list includes two parameters for each LFE. One parameter is an index value 162 (called an index parameter) that is derivable from an identifier that identifies the LFE (called LFE identifiers). The other parameter is a controller identifier 164 (called a controller identifier) that identifies a controller that is responsible for processing requests for the LFE. In some embodiments, the controller identifier is an address (e.g., IP address) of the controller, while in other embodiments, the controller identifier is a value from which the address of the controller can be obtained (e.g., through another table).
For each type of LFE managed by the network control system, the controllers and the hosts use the same index generation process to generate the index values for different LFEs of the same type. In some embodiments, the controllers and the hosts use the same index generation process for different types of LFEs, while in other embodiments they use different index generation process for different types of LFEs. In some embodiments, one controller (i.e., a master controller) creates the controller list by assigning each LFE to a controller, using the appropriate index generation process or processes to generate the index values from the LFE identifiers, and creating for each LFE a record in the controller list that specifies the LFE's assigned controller in terms of the controller's identifier and the LFE's derived index value. In some embodiments, the controller set (e.g., the master controller) does not explicitly generate the index values from the LFE identifiers (the LFEIs), but rather assigns a defined range of index values (associated with a range of LFEIs) to the different controllers, as further described below.
An agent of a host can identify the controller for a particular LFE implemented by the host's PFE by (1) using the index generator 132 for the correct LFE type to generate an index value and (2) using the generated index value to retrieve the controller identifier from the controller assignment list 160 that is stored in the storage 156. The retrieved controller identifier specifies the controller for the agent to connect to in order to obtain necessary data for processing requests associated with the particular LFE's operations. As mentioned above, the controller identifier in some embodiments specifies the address of the controller, while in other embodiments this identifier is used to retrieve the address of the controller (e.g., through another table). In some embodiments, the agent identifies a controller for an LFE when it sets up the LFE on the host, or upon receiving a new controller assignment list from the controller. In some of these embodiments, the agent establishes a connection (e.g., a TCP/IP session) with the LFE's controller upon identifying the controller, so that it can later use this connection to process subsequent LFE operations that need the controller's input.
The index generation process of some embodiments is a hash operation that maps identifiers for different types of LFEs to the same range of index values. For instance, in some embodiments, the hash operation ends with a modulo operation that expresses the final hashed index value in terms of an integer that is the remainder value of the operation. Using this approach, the controller set (e.g., the master controller) assigns the controllers to different ranges of the possible hash value without explicitly generating any index value for any LFEI. In some embodiments, the assignment of the controllers to different ranges of hash values is done in a manner to achieve a desired load balancing across the controllers. For instance, in some embodiments, this assignment is uniform or approximately uniform in terms of the number of controllers and the number of LFEs. In some embodiments, the controller cluster (e.g., the master controller) assigns equal sized hash value ranges to different controllers as its distribution scheme distributes the LFE identifiers uniformly across the LFEI range in order to ensure even distribution across the hash value ranges. In other embodiments, this assignment is uniform or approximately uniform in terms of data that is collected dynamically, such as data traffic load for each LFE, the number of VMs for each LFE, etc.
As mentioned above, using a hash/modulo process allows the distribution scheme of some embodiments to assign a defined range of index values to the different controllers without requiring the controller set (e.g., the master controller) to explicitly compute an index value for each LFE. Only the host agents need to use the hashing process to generate an index value that identifies a controller in the controller assignment list. In some embodiments, the same hash/modulo process is used for different LFE types, as mentioned above. In other embodiments, different hash/modulo processes are used for different LFE types (e.g., in order to allow different LFE types to different hash value ranges).
Several more detailed examples of the operation of the agents 150 will be further described in Section I below. Next, in Section II, the operation of the controller cluster of some embodiments will further be described. Finally, Section III describes an electronic system with which some embodiments are implemented.
I. Host Side Operations
However, unlike the computers 122-128, the computers 322-328 in the control system 300 each have two types of physical forwarding elements 372 and 374, two index generators 351 and 353, and a connection list 375. The two PFE types on each computer are an L2 switch 372 and an L3 router 374. Both these elements are software forwarding elements that execute on host computers 322-328.
These elements are managed by the controller cluster 101 to implement different logical switches (LS's) and different logical routers (LRs) for different virtual networks of different tenants, users, departments, etc. that use the same shared compute and networking resources. For instance, as shown in
Like agents 150 and proxies 154 of control system 100, the agents 350 and proxies 154 of the control system 300 are used to obtain data in real-time from the controller cluster 101 in order to facilitate the performance of some of the LFE operations (i.e., LS operations or LR operations). Like the agents 150 of the system 100, the agents 350 of the system 300 (1) review the controller assignment list 160 that the controller cluster 100 distributes to identify the appropriate controllers for the various different LFEs, and (2) establish control communication channels with these controllers so that they can later use communication channels to obtain the needed data for effectuating subsequent forwarding operations of their associated LFEs.
The agents 350 of the system 300 use two different index generators 351 and 353 to generate index values for two different types of logical forwarding elements that their hosts execute. Specifically, the agents use the index generator 351 to generate index values for the different logical switches that their associated L2 switches 372 implement, while using index generator 353 to generate index values for the different logical routers that their associated L3 routers 374 implement. The index generator 351 generates its index values from the logical switch (LS) identifiers that identify the different LS's, while the index generator 353 generates its index values from the logical router (LR) identifiers that identify the different LRs. In some embodiments, the LS or LR identifier is an identifier that uniquely specifies a logical switch or logical router in a locality (e.g., a data center or a group of hosts in a data center), while in other embodiments the identifier is an identifier that represents an LFE that spans multiple localities (e.g., spans two data centers). As mentioned above, the LS identifier in some embodiments is the VNI of a logical switch. While
In some embodiments, the agent uses the index generator and the controller assignment list when it is setting up a LS or LR on its host, or when it receives a new controller assignment list to process from the controller. After obtaining an index value for a particular LS or LR from an index generator, an agent (1) uses the generated index value to retrieve the controller identifier from the controller assignment list 160, (2) establishes a connection (e.g., a TCP/IP session) with the identified controller, and (3) stores the identity of this controller and/or this established connection in the connection list 375. As further described below, the agent subsequently uses the connection list 375 to identify the controller or connection to use to process subsequent operations of the particular LS or LR.
The operation of an agent 350 in the control system 300 will now be further described by reference to the process 600 of
As shown in
Next, at 615, the process selects a logical forwarding element (LFE) that a physical forwarding element of its host has to implement or should be prepared to possibly implement. In some embodiments, even when a host's PFE is not implementing an LFE, it is set up for the LFE so that it can be ready to seamlessly join the implementation of the LFE when a VM that uses the LFE is instantiated on the host. For instance, in some embodiments, a host is prepared to implement an LFE when the host is part of a computational cluster of hosts and one of the other hosts in the cluster is currently implementing the LFE.
As mentioned above, examples of LFEs include LS's and LRs. Accordingly, at 615, the process may select any LS or LR that it has to implement or should be prepared to implement. Next, at 620, the process uses the selected LFE's identifier to generate an index value. To do this, the process uses the index generator 351 or 353 that is appropriate for the LFE's type (e.g., uses the L2 index generator if the selected LFE is a LS, and uses the L3 index generator when the selected LFE is a LR). As mentioned above, some embodiments use one index generator for different types of LFEs.
At 625, the process uses the generated index value to retrieve the identity of the controller for the selected LFE (i.e., the LFE selected at 615) from the controller assignment list. In other words, at 625, the process identifies the record in the list that has an index value that matches the generated index value, and retrieves the controller identifier of this identified record.
At 630, the process determines whether it previously created a connection to the identified controller (i.e., the controller identified at 625) for another LFE. This determination is made because the process 600 of some embodiments only makes one control channel connection between each host agent and a controller, and uses this connection to obtain from the controller data for all LFEs handled by the controller. In other embodiments, however, the process establishes multiple control channel connections between an agent and a controller, because the process in these embodiments establishes a unique control channel connection between the agent and the controller for each LFE handled by the controller.
When the process determines (at 630) that it previously created a connection to the identified controller, it adds (at 635) a new record in the connection list to specify this connection and/or the identified controller for the LFE selected at 615. The creation of records in the connection list is further described below by reference to operation 645. At 635, the process of some embodiments uses the previously specified connection to send to the controller dynamic data pertaining to the selected LFE. Examples of such data include ARP table for an L2 logical switch and a routing table for an L3 logical router. The controller uses this data to subsequently process data requests from the agent. From 635, the process transitions to 650, which will be further described below.
When the process determines (at 630) that it did not previously create a connection to the identified controller, it establishes (at 640) a connection with the controller identified at 625. In some embodiments, the connection is a TCP/IP connection. The agent will subsequently use this connection to communicate with the controller to process certain operations of the LFE. In some embodiments, the controller might reject a request from the process 600 to establish a connection to handle data requests for a particular LFE. For instance, in some cases, the controller might not have received the controller assignment list that specifies that the controller is responsible for the particular LFE. To account for such circumstances, the process 600 sets a timer (at 630) when its connection request is rejected, so that it can re-submit the request again once the timer expires, by which time the controller should have received the new controller assignment list. In some embodiments, the process re-sets the timer multiple times when the controller rejects a connection request multiple times, in order to give the controller sufficient time to receive a new controller assignment list. The setting and use of this timer will be further described below by reference to
At 640, the process also sends dynamic data to the controller once the controller accepts the connection. This dynamic data includes data pertaining to the selected LFE. Examples of such data include an ARP table for an L2 logical switch and a routing table for an L3 logical router. The controller uses this data to subsequently process data requests from the agent (e.g., process ARP requests from the host agents, or distribute routing table to the hosts).
After 640, the process stores (at 645) the identity of the new controller and/or identity of the newly established connection in the connection list 375 for the LFE. Specifically, in some embodiments, a record is created in the connection list that specifies the LFE, the identifier for its associated controller, and the identifier for the connection session. In some embodiments, the connection session is not stored in this connection list. As mentioned above, and further described below, the agent uses the connection list to process subsequent LFE operations that need controller input.
At 650, the process determines whether it has examined all the LFEs that its host has to implement or be prepared to implement. If so, it transition to 655, which will be further described below. Otherwise, the process transitions to 615 to select another LFE and repeat its operations 620-650 for this LFE.
To further explain operations 620-645,
In
When the process determines (at 650) that it has examined all the LFEs that its host has to implement or be prepared to implement, it uses (at 655) the controller connections specified in the connection list to process subsequent LFE operations that need controller input, until the agent receives an update to the controller assignment list. The operation of the agent when it receives an updated controller assignment list will be further described below by reference to
(1) from a VM's associated proxy 154, receives a request for data for performing an operation for LS 20 with which the VM is associated,
(2) searches the connection list for the controller responsible for LS 20,
(3) retrieves the identifier (e.g., the IP address) of controller 1,
(4) sends a request for the desired data to the identified controller 1,
(5) receives the requested data from the controller 1, and
(6) passes the received data to the requesting proxy.
An example of such an LS request is an ARP (address resolution protocol) request. A VM sends an ARP request when it needs to identify the MAC (media access control) address for another VM or device for which it has an IP address. ARP requests are broadcast requests that consume a lot of resources in hosted, virtualized environments, especially as the number of hosts and/or VMs increases. Accordingly, some have suggested a proxy based scheme for suppressing ARP broadcast messages, as described in concurrently filed U.S. patent application Ser. No. 14/070,360, entitled “Proxy Methods for Suppressing Broadcast Traffic in a Network,” now issued as U.S. Pat. No. 9,548,965. In this scheme, a proxy (like proxy 152 of
In the example illustrated in
(1) from a VM's associated proxy 154, receives a request for data for performing an operation for LR 73 with which the VM is associated,
(2) searches the connection list for the controller responsible for LR 73,
(3) retrieves the identifier (e.g., the IP address) of controller 3,
(4) sends a request for the desired data to the identified controller 3,
(5) receives the requested data from the controller 3, and
(6) passes the received data to the requesting proxy.
An example of such a LR request is a DHCP (dynamic host configuration protocol) request. A VM sends a DHCP discover broadcast when it needs to identify a DHCP server to provide it with DHCP configuration data. Like ARP requests, DHCP requests are broadcast requests that consume a lot of resources in hosted, virtualized environments, especially as the number of hosts increases. Accordingly, some have suggested a proxy based scheme for suppressing DHCP broadcast messages, as described in U.S. patent application Ser. No. 14/070,360, entitled “Proxy Methods for Suppressing Broadcast Traffic in a Network,” now issued as U.S. Pat. No. 9,548,965. In this scheme, a proxy (like proxy 152 of
Another example of processing LR requests relates to the operation of publishing routing tables from an edge virtual router to non-edge virtual routers. An edge virtual router is a virtual router that handles north or south traffic out of or and into the virtual L3 network. The non-edge virtual routers are virtual routers that handle east-west traffic within the virtual L3 network. In a virtual L3 network that has both edge and non-edge virtual routers, the edge routers publish their routing tables to the non-edge virtual routers. To do this, each edge virtual router of a virtual L3 network uses the controller identification process of some embodiments to identify the correct controller to send its routing tables, so that this controller can push these tables to the non-edge virtual routers in the same virtual L3 network or can serve as a node from which these non-edge virtual routes can pull these tables.
It does not include the subscription operation 605 as the agent previously subscribed to a controller to receive updates to the controller assignment list. Also, the storage operation 610 is not shown in
The process 1100 performs the operation 1105 to identify new controller assignments for the LFEs. Specifically, after identifying a controller (in the controller assignment list) for a selected LFE, the process 1100 determines (at 1105) whether it previously specified the identified controller as the controller for the selected LFE in the connection list 375. If so, it skips operations 640, 645, and 1110, and transitions to 650.
Otherwise, the process 1100 transitions to 640 to perform the above-described operations 640 and 645 to establish a connection with the newly specified controller identified at 625 and store the identity of this controller and/or this connection in the connection list for the selected LFE. After recording this controller and/or connection in the connection list, the process 1100 closes (at 1110) the connection to the controller that was previously specified for the selected LFE, if this connection is not being used by the host's agent for any other LFE. Also, at 1110, the process removes this previous connection from the connection list for the LFE. In some embodiments, the process 1100 performs the operations at 1110 before it records (at 645) the new connection to the new controller.
In some embodiments, each time that each controller sends its subscribed hosts updated controller lists, it might not include the entire list, but only include the records in this list that have been updated. This might be the case because in some embodiments, the master controller does not distribute the controller assignment list in its entirety each time that it updates this list. Rather, each time that it updates a portion of the master controller list, the master controller of some embodiments also distributes only the portion of the controller assignment list that it has updated.
II. Controller Side Operation
In some embodiments, the coordination management layer has a coordination manager instance executing on each controller. In these embodiments, the different instances of the coordination manager on the different controllers communicate in order to achieve several objectives. These objectives in some embodiments include: (1) keeping status of all controller nodes, such as their IP address, their UUID (universally unique identifier), and when they join/leave the cluster, (2) synchronizing data between controller nodes, and (3) selecting a master for the control-cluster, and reselecting the master when the previous master controller leaves the cluster. One example of a distributed coordination management layer that can be used to perform this functionality is the Zookeeper program. Additional examples of the coordination management layer are described in U.S. Published Patent Application 2013/0058356.
As shown in
The second operation is the master controller 102 generating the controller assignment list, and sending this list to the other controllers. The third operation is the non-master controllers receiving the controller assignment list. As shown in
Different embodiments have the master controller generate the controller list differently. For instance, some embodiments have the agents use a hash/modulo operation that maps all possible LFE identifiers to a common range of index values. For some of these embodiments, the master controller does not explicitly generate the index values for the different possible LFE identifiers. Rather, it simply segments the possible index values into several different ranges, and assigns the different ranges to the different controllers.
In the example illustrated in
The host agents can then use the generated index values to retrieve controller identifiers from the controller assignment list for the different LFEs. Based on the values of the LS and LR identifiers, some of the index values may go unused by the host agents. However, the use of the hash/modulo index value generator(s) by the host agents allows the controller cluster (e.g., the master controller) to forego explicitly computing an index value for each LFE.
In other embodiments, the master controller uses index value generators to generate index values for the different possible LFE identifiers.
As shown in
After generating the index value for the selected LFE identifier, the process 1500 associates (1515) a controller to the generated index value according to a distribution process that maximizes the even distribution of the generated index values among the controllers. Next, at 1520, the process determines whether it has iterated through all the LFE identifiers. If so, it ends. Otherwise, it returns to 1505 to select another LFEI and to repeat operations 1510, 1515, and 1520.
Once the process finishes iterating through all the possible LFE identifiers, it has built the controller assignment list.
In still other embodiments, the master controller uses still other schemes for generating the index values. For instance, unlike the example illustrated in
The above-described controller assignment processes assign controllers to ranges of index values and distribute loads across the controllers based on statically expressed parameters. For instance, some of the above-described processes distribute the index value range evenly amongst the controllers. However, such static approach might not accurately track the dynamic realities of the network control system. For instance, even when the number of LFE identifiers assigned to a first controller equal the number of LFE identifiers assigned to a second controller, the LFEs assigned to the first controller might impose more burden on the first controller, than the LFEs assigned to the second controller assign to this controller.
Accordingly, the master controller of some embodiments assigns the LFEs to the different controllers based on dynamically gathered data, such as the number of VMs assigned to each controller, the number of packets passing through the LFEs, the number of host-controller connections for each controller, or other dynamically collected data regarding the load on the LFEs and/or controllers.
In some embodiments, for each LFE identifier, an index generator computes a traffic weight factor based on the number of hypervisors connected, stats of the traffic (ARP messages, route update messages, etc), the scale of configurations (e.g. how many L2 networks are included in the L3 component), etc. The index generator then generates the hash value as an exponential operation on the “weight” value. This results in the larger weight values being distributed more sparsely in the hash table, which increases the possibility of distributing them to different controller nodes. In some embodiments, the actual weight value falls into a large range, and this makes unlikely that two identifiers have the same weight.
For the embodiments illustrated by
In some of these embodiments, the controller assignor does not need index values to be generated, as it maintains its controller assignment list in terms of the LFE identifiers. Specifically, the controller assignor uses the dynamically collected data 1950 to assign different LFEs, and to adjust dynamically the different LFEs, to the different controllers, and to express these assignments in terms of the LFEIs.
Foregoing index generators in the host computers is advantageous in that it does not require the controller assignment list to be distributed each time that it is modified based on dynamically collected data. On the other hand, in embodiments where the controller assignment list is not frequently updated based on the dynamically collected data, having the hosts generate the index values is preferable as it does not add to the master controller the load associated with the building of each host's connection list.
Upon noting the addition of the new controller, the master controller 102 generates a new controller assignment list, and distributes this new list to the other controllers 104, 106 and 108, as shown in
To do this, the master controller in some embodiments takes the same fraction of the LFE assignments or index value range assignments (e.g., one over the number of the previous controllers plus the number of added controller(s)) from each previous controller's assigned range and adds this fraction to the assignment of the new controller(s).
In some embodiments, the master controller also runs a timer, which when expired causes the master controller to check periodically that the controller nodes are well balanced. Whenever it detects that the controllers are not well balanced, the master controller will generate and send a new controller assignment list.
Whenever the master controller sends a controller assignment list update, the hosts will receive their updates from the controllers (including the master controller) to which they subscribed to receive such updates. Also, when such updates re-assign an LFE from one controller to another, the host agents that deal with this LFE have to close their connection to the previous controller and establish a new connection to the new controller, if such a connection is needed.
In some cases, the new controller for an LFE might receive and/or process its new controller assignment list after a host receives and processes this list for the LFE. If that is the case, the new controller and host will have inconsistent states. To handle this case, the controller is configured to reject a connection by a host agent for a particular LFE until the controller's assignment list specifies that it should accept connections for the particular LFE. In such situations, the host agent starts a timer and tries again to establish the connection with the new controller upon the expiration of the timer.
In some embodiments, the master controller may not distribute the controller assignment list in its entirety each time that it updates this list. Rather, each time that it updates a portion of the master controller list, the master controller of some embodiments might only distribute the portion of the controller assignment list that it has updated. Similarly, in some embodiments, each time that each controller sends its subscribed hosts updated controller lists, it might not include the entire list, but only include the records in this list that have been updated.
When a controller fails, the master controller has to re-specify the controller assignment list. As in the case of the addition of a controller, the master controller of some embodiments re-specifies the controller assignment list in order to minimize the LFE assignments or index value assignments to each of the remaining controllers.
After 2205, the process 2200 re-specifies (at 2210) the controller assignment list, distributes (at 2215) the newly specified controller assignment list to the other controllers, and then ends. In some embodiments, the process re-specifies (at 2210) the controller assignment list in order to minimize index value assignments to each of the remaining controllers. For instance, in some embodiments, the master's controller assignor incrementally modifies each controller's existing assignment so that no one controller's assignment is drastically increased or modified. To do this, the master controller in some embodiments takes the same fraction of the LFE assignments or index value range assignments (e.g., one over the number of the remaining controllers) from the failed controller's previous assignments and adds this fraction to the assignment of the remaining controllers.
III. Electronic System
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 2405 collectively represents all system, peripheral, and chipset buses that communicatively connect the numerous internal devices of the electronic system 2400. For instance, the bus 2405 communicatively connects the processing unit(s) 2410 with the read-only memory 2430, the system memory 2425, and the permanent storage device 2435.
From these various memory units, the processing unit(s) 2410 retrieve instructions to execute and data to process in order to execute the processes of the invention. The processing unit(s) may be a single processor or a multi-core processor in different embodiments.
The read-only-memory (ROM) 2430 stores static data and instructions that are needed by the processing unit(s) 2410 and other modules of the electronic system. The permanent storage device 2435, on the other hand, is a read-and-write memory device. This device is a non-volatile memory unit that stores instructions and data even when the electronic system 2400 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 2435.
Other embodiments use a removable storage device (such as a floppy disk, flash drive, etc.) as the permanent storage device. Like the permanent storage device 2435, the system memory 2425 is a read-and-write memory device. However, unlike storage device 2435, the system memory is a volatile read-and-write memory, such a random access memory. The system memory 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 2425, the permanent storage device 2435, and/or the read-only memory 2430. From these various memory units, the processing unit(s) 2410 retrieve instructions to execute and data to process in order to execute the processes of some embodiments.
The bus 2405 also connects to the input and output devices 2440 and 2445. The input devices enable the user to communicate information and select commands to the electronic system. The input devices 2440 include alphanumeric keyboards and pointing devices (also called “cursor control devices”). The output devices 2445 display images generated by the electronic system. The output devices 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.
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. In addition, a number of the figures (including
This application is a continuation of U.S. patent application Ser. No. 14/070,451, filed Nov. 1, 2013, now published as U.S. Patent Publication 2015/0103661. U.S. patent application Ser. No. 14/070,451 claims benefit to U.S. Provisional Patent Application 61/889,519, filed Oct. 10, 2013, and U.S. Provisional Patent Application 61/890,321, filed Oct. 13, 2013. U.S. Provisional Patent Application 61/889,519, U.S. Provisional Patent Application 61/890,321, and U.S. patent application Ser. No. 14/070,451 are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5504921 | Dev et al. | Apr 1996 | A |
5550816 | Hardwick et al. | Aug 1996 | A |
5729685 | Chatwani et al. | Mar 1998 | A |
5751967 | Raab et al. | May 1998 | A |
5796936 | Watabe et al. | Aug 1998 | A |
5825779 | Putnins et al. | Oct 1998 | A |
6104699 | Holender et al. | Aug 2000 | A |
6219699 | McCloghrie et al. | Apr 2001 | B1 |
6512745 | Abe et al. | Jan 2003 | B1 |
6539432 | Taguchi et al. | Mar 2003 | B1 |
6680934 | Cain | Jan 2004 | B1 |
6785843 | McRae et al. | Aug 2004 | B1 |
6842768 | Shaffer et al. | Jan 2005 | B1 |
6941487 | Balakrishnan et al. | Sep 2005 | B1 |
6963585 | Pennec et al. | Nov 2005 | B1 |
7079544 | Wakayama et al. | Jul 2006 | B2 |
7096228 | Theimer et al. | Aug 2006 | B2 |
7197572 | Matters et al. | Mar 2007 | B2 |
7200144 | Terrell et al. | Apr 2007 | B2 |
7209439 | Rawlins et al. | Apr 2007 | B2 |
7286490 | Saleh et al. | Oct 2007 | B2 |
7359971 | Jorgensen | Apr 2008 | B2 |
7450598 | Chen et al. | Nov 2008 | B2 |
7483370 | Dayal et al. | Jan 2009 | B1 |
7606260 | Oguchi et al. | Oct 2009 | B2 |
7649851 | Takashige et al. | Jan 2010 | B2 |
7710874 | Balakrishnan et al. | May 2010 | B2 |
7730486 | Herington | Jun 2010 | B2 |
7792987 | Vohra et al. | Sep 2010 | B1 |
7818452 | Matthews et al. | Oct 2010 | B2 |
7826482 | Minei et al. | Nov 2010 | B1 |
7885276 | Lin | Feb 2011 | B1 |
7937438 | Miller et al. | May 2011 | B1 |
7948986 | Ghosh et al. | May 2011 | B1 |
8027354 | Portolani et al. | Sep 2011 | B1 |
8046456 | Miller et al. | Oct 2011 | B1 |
8054832 | Shukla et al. | Nov 2011 | B1 |
8055789 | Richardson et al. | Nov 2011 | B2 |
8166201 | Richardson et al. | Apr 2012 | B2 |
8223668 | Allan et al. | Jul 2012 | B2 |
8224931 | Brandwine et al. | Jul 2012 | B1 |
8224971 | Miller et al. | Jul 2012 | B1 |
8312129 | Miller et al. | Nov 2012 | B1 |
8456984 | Ranganathan et al. | Jun 2013 | B2 |
8504718 | Wang et al. | Aug 2013 | B2 |
8621058 | Eswaran et al. | Dec 2013 | B2 |
8644188 | Brandwine et al. | Feb 2014 | B1 |
8705513 | Merwe et al. | Apr 2014 | B2 |
9021098 | Nagle | Apr 2015 | B1 |
9596126 | Shen et al. | Mar 2017 | B2 |
10148484 | Shen et al. | Dec 2018 | B2 |
10225270 | Reddy et al. | Mar 2019 | B2 |
10374830 | Datta et al. | Aug 2019 | B1 |
20030006919 | Collins et al. | Jan 2003 | A1 |
20030093481 | Mitchell et al. | May 2003 | A1 |
20040047286 | Larsen et al. | Mar 2004 | A1 |
20040073659 | Rajsic et al. | Apr 2004 | A1 |
20040098505 | Clemmensen | May 2004 | A1 |
20040267897 | Hill et al. | Dec 2004 | A1 |
20050018669 | Arndt et al. | Jan 2005 | A1 |
20050038834 | Souder et al. | Feb 2005 | A1 |
20050083953 | May | Apr 2005 | A1 |
20050120160 | Plouffe et al. | Jun 2005 | A1 |
20060002370 | Rabie et al. | Jan 2006 | A1 |
20060026225 | Canali et al. | Feb 2006 | A1 |
20060092940 | Ansari et al. | May 2006 | A1 |
20060092976 | Lakshman et al. | May 2006 | A1 |
20060174087 | Hashimoto et al. | Aug 2006 | A1 |
20060184937 | Abels et al. | Aug 2006 | A1 |
20060193266 | Siddha et al. | Aug 2006 | A1 |
20070043860 | Pabari | Feb 2007 | A1 |
20070156919 | Potti et al. | Jul 2007 | A1 |
20070220059 | Lu et al. | Sep 2007 | A1 |
20070220358 | Goodill et al. | Sep 2007 | A1 |
20070260721 | Bose et al. | Nov 2007 | A1 |
20070283348 | White | Dec 2007 | A1 |
20070297428 | Bose et al. | Dec 2007 | A1 |
20080002579 | Lindholm et al. | Jan 2008 | A1 |
20080040467 | Mendiratta et al. | Feb 2008 | A1 |
20080049621 | McGuire et al. | Feb 2008 | A1 |
20080059556 | Greenspan et al. | Mar 2008 | A1 |
20080071900 | Hecker et al. | Mar 2008 | A1 |
20080080559 | Singh | Apr 2008 | A1 |
20080159301 | Heer | Jul 2008 | A1 |
20080165704 | Marchetti et al. | Jul 2008 | A1 |
20090067331 | Watsen et al. | Mar 2009 | A1 |
20090296726 | Snively et al. | Dec 2009 | A1 |
20100039296 | Marggraff et al. | Feb 2010 | A1 |
20100125667 | Soundararajan | May 2010 | A1 |
20100169441 | Lafleur et al. | Jul 2010 | A1 |
20100177789 | Chen et al. | Jul 2010 | A1 |
20110103259 | Aybay et al. | May 2011 | A1 |
20110296052 | Guo et al. | Dec 2011 | A1 |
20120075991 | Sugita et al. | Mar 2012 | A1 |
20120120964 | Koponen et al. | May 2012 | A1 |
20120147894 | Mulligan et al. | Jun 2012 | A1 |
20120226799 | Kapur et al. | Sep 2012 | A1 |
20130024579 | Zhang et al. | Jan 2013 | A1 |
20130044752 | Koponen et al. | Feb 2013 | A1 |
20130103817 | Koponen | Apr 2013 | A1 |
20130332602 | Nakil et al. | Dec 2013 | A1 |
20130332619 | Xie et al. | Dec 2013 | A1 |
20140050223 | Foo et al. | Feb 2014 | A1 |
20140089488 | Chong et al. | Mar 2014 | A1 |
20140181829 | Hathaway et al. | Jun 2014 | A1 |
20140229944 | Wang et al. | Aug 2014 | A1 |
20140241247 | Kempf et al. | Aug 2014 | A1 |
20140280836 | Kumar et al. | Sep 2014 | A1 |
20140351229 | Gupta | Nov 2014 | A1 |
20140355516 | Baudoin et al. | Dec 2014 | A1 |
20150009995 | Gross, IV et al. | Jan 2015 | A1 |
20150103645 | Shen et al. | Apr 2015 | A1 |
20150103661 | Shen et al. | Apr 2015 | A1 |
20160080244 | Retana et al. | Mar 2016 | A1 |
20160099853 | Nedeltchev et al. | Apr 2016 | A1 |
20160105377 | Nakagawa | Apr 2016 | A1 |
20160119156 | Drake et al. | Apr 2016 | A1 |
20160330070 | Datta et al. | Nov 2016 | A1 |
20160330111 | Manghirmalani et al. | Nov 2016 | A1 |
20160380886 | Blair et al. | Dec 2016 | A1 |
20170063674 | Maskalik et al. | Mar 2017 | A1 |
20170078207 | Atkins et al. | Mar 2017 | A1 |
20170235774 | Colgrove et al. | Aug 2017 | A1 |
20170359247 | Dixon | Dec 2017 | A1 |
20180006935 | Mutnuru et al. | Jan 2018 | A1 |
20180159957 | Hooda et al. | Jun 2018 | A1 |
20190028300 | Mathew et al. | Jan 2019 | A1 |
20190045031 | Feghali et al. | Feb 2019 | A1 |
20190104111 | Cidon et al. | Apr 2019 | A1 |
20190149512 | Sevinc et al. | May 2019 | A1 |
20190238363 | Boutros et al. | Aug 2019 | A1 |
20200014638 | Chen et al. | Jan 2020 | A1 |
20200014663 | Chen et al. | Jan 2020 | A1 |
20200162377 | Sarva et al. | May 2020 | A1 |
20200177458 | Rahman et al. | Jun 2020 | A1 |
Number | Date | Country |
---|---|---|
2013184846 | Dec 2013 | WO |
2020009784 | Jan 2020 | WO |
Entry |
---|
Author Unknown, “Virtual Machine Backup Guide,” Nov. 2007, 78 pages, VMware, Inc., Palo Alto, California. |
Author Unknown, “Apache Cassandra™ 1.2 Documentation,” Jan. 13, 2013, 201 pages, DataStax. |
Number | Date | Country | |
---|---|---|---|
20190075012 A1 | Mar 2019 | US |
Number | Date | Country | |
---|---|---|---|
61890321 | Oct 2013 | US | |
61889519 | Oct 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14070451 | Nov 2013 | US |
Child | 16179971 | US |