The present disclosure relates to distributed transaction computer systems. More particularly, the present disclosure relates to capacity planning and resource optimization in distributed transaction computer systems.
The great progress in online services during the last decade has led to a dramatic increase of system complexity. Nowadays, typical systems such as GOOGLE and AMAZON contain thousands of components including operating systems, application software, servers, and networking and storage devices, which deal with millions of user queries or transactions every day. Users of online services always expect high Quality of Services (QoS), which has as one important criterion short latency, among others.
However, a sudden increase of user workload will probably lead to a system bottleneck on some components, hence deteriorates QoS. While sufficient hardware resources need to be deployed to ensure high QoS, meanwhile, an oversized system with scale could be a huge waste of resources. Therefore, it is very important to match resource assignments with capacity needs for each component in large scale systems.
Although static capacity planning for standalone software might be simple, it is difficult to specify the capacity needs for online service systems because they usually vary with user workloads. In other words, fixed numbers of capacity are not able to give a good specification. Due to the dynamic nature of user workloads, a mathematical model is highly desired to capture their hidden relationship with system capacity needs. Moreover, the model should be general enough to be applicable to different types of system resources, such as CPU, disk I/O, memory, and so on.
Co-pending U.S. patent application Ser. No. 11/860,610, filed Sep. 25, 2007, and assigned to the assignee herein, addresses the capacity planning problems associated with large scale computer systems. U.S. patent application Ser. No. 11/860,610 discloses a method and apparatus that extracts pair-wise relationships between computer system measurements, but does not address relationships involving multiple system measurements.
Accordingly, a method and apparatus is needed for capacity planning and resource optimization in large scale computer systems, which addresses the relationship among multiple system measurements.
A method is disclosed herein for determining the capacity needs of components in a distributed computer system. In the method, a pair-wise invariant network is determined from collected flow intensity measurement metrics or nodes. The network includes at least three separate and unconnected pair-wise invariant subnetworks, each of the subnetworks including two or more of the measurement nodes and one or more pairwise invariants, each of the pairwise invariants connecting two of the two or more measurement nodes, and each of the pair-wise invariants characterizing a constant relationship between their two connected measurement nodes. One of the measurement nodes is selected from each of the subnetworks as a representative measurement node. A minimal redundancy least regression process is performed to extract at least one overlay invariant from the representative measurement nodes. The capacity need of the at least one component is determined using the pair-wise and overlay invariants
An apparatus is also disclosed herein for determining the capacity needs of the components in a distributed computer system. The apparatus comprises a processor executing instructions for determining, from collected flow intensity measurement nodes, a pair-wise invariant network, the network including at least three separate and unconnected pair-wise invariant subnetworks, each of the subnetworks including two or more of the flow intensity measurement nodes and one or more pairwise invariants, each of the pairwise invariants connecting two of the two or more measurement nodes, and each of the pair-wise invariants characterizing a constant relationship between their two connected measurement nodes. The processor of the apparatus also executes instructions for selecting one of the measurement nodes from each of the subnetworks as a representative nodes and performing a minimal redundancy least regression to extract at least one overlay invariant from the representative nodes. The capacity needs of the components are determined using the pair-wise and overlay invariants.
A method and apparatus are disclosed herein for estimating or planning the capacity needs of the components of a distributed transaction (large scale) computer system using pair-wise and overlay invariants of the system. Most distributed transaction computer systems, such as Internet services, employ multi-tier architectures to integrate their components.
The web servers 110 operate as an interface, or gateway, to present data to the browser of the one or more client computers 105. The application server 115 supports specific business, or application logic for various applications, which generally includes the bulk of an application. The database servers 120 are used for data storage.
The distributed computer system 100 further includes a capacity planning module 130 to determine the resources needed for the distributed computer system 100. The capacity planning module 130 can be executed on one or more of the web, application, and database servers 110, 115, 120. Alternatively, the capacity planning module 130 can be executed on its own server or computer (not shown).
One of ordinary skill in the art will appreciate that the methods described herein can be applied to distributed computer systems having other types of components and tiers.
The web, application, and database components 110, 115, and 120 of the distributed computer system 100 shown in
During operation, the distributed computer system 100 produces large amounts of monitoring data or metrics, such as log files, to track its operational status. In accordance with the method and apparatus of the present disclosure, these metrics are measured from the various components of the distributed computer system 100, i.e., the web, application and data servers 110, 115 and 120, the client computers 105, the system networks, and from the application workloads. CPU usage, network traffic volume, and number of SQL queries are non-limiting examples of monitoring metrics that may be measured. Measurement metrics of various resource utilizations can be obtained from the web, application and data servers 110, 115 and 120 and the client computers 105, such as CPU, memory, and disk utilizations. Measurement metrics about network packets can be obtained from the networks of the distributed computer system. System workload measurement metrics can be obtained as the number of user requests entering the distributed computer system. User requests traverse a set of the system components and software paths according to application logic. Much of the internal monitoring metrics of the distributed computer system reacts to the volume of user requests.
While a large volume of user requests flow through various components in the distributed computer system 100, many resource consumption related measurement metrics respond to the intensity of user loads, accordingly. Therefore, flow intensity, as used herein, refers to the intensity with which internal measurement metrics respond to the volume of (i.e., number of) user loads. Based on this definition of flow intensity, constant linear relationships between two flow intensities can be determined at various points across the distributed computer system 100 in accordance with the present disclosure. If a constant linear relationship between two flow intensity measurement metrics always hold true under various workloads over time, this linear relationship is referred to herein as a pair-wise invariant or pair-wise invariant model of the distributed computer system 100.
Pair-wise invariants are in a form of a linear regression model as x1=f(x2)=wx2 w0, where x1 and x2 are different distributed computer system measurements. As shown in
Although the pair-wise invariants provide a relatively general model for capacity planning, they only capture relationships between two different system measurements, while some relationships involve multiple ones as in the three-tier distributed computer system of
Referring again to
The overly invariants are disposed over the pair-wise invariant network, and act like bridges to connect the originally separated pair-wise invariant subnets A, B, And C together. The overlay invariants take multiple inputs (x1→x3 and x10→x11) because an exhaustive search has been done for the pair-wise invariants.
In block 320, overlay invariants are extracted using representative system measurement nodes selected from each of the pair-wise invariant subnets of the pair-wise invariant network. The extracted overlay invariants form an overlay invariant network that connects together the originally separated pair-wise invariant subnets, as well as any isolated measurement nodes, thereby enabling the volume of workload to propagate across the previously disconnected subnets for capacity planning.
In block 340, the capacity needs of the components of the distributed computer system are estimated using the pair-wise invariant network and the corresponding overlay invariant network. The resulting overlay invariant network extends the connectivity among the previous disconnected pair-wise subnets so that the volume of workloads can be propagated to more nodes (system components) in distributed computer systems to estimate the capacity needs and optimize resource optimization. So with the same monitoring measurement metrics, it is possible to obtain higher quality capacity planning and resource optimization because the overlay invariant network extends the connectivity between the volume of workload and the resource usages of various computer system components.
The invariant extraction method defines flow intensity xi as an intensity measurement node of resource consumption related data, such as CPU usage, network traffic volume, etc. For every pair of measurement nodes (xi,xj), the method extracts a linear relationship in the form of xi=w1xj+w0, which is evaluated by a fitness score. For any measurement x=x(1) . . . x(T) over time t=1 . . . T, given the estimation {circumflex over (x)}={circumflex over (x)}(1) . . . {circumflex over (x)}(T), the fitness score is defined as
where
In one embodiment, the overlay invariant relationships are extracted from multiple system measurements using Least Angle Regression (LAR), which is a well known regression algorithm for variable selection. Given a response, LAR selects one input at a time based on the correlation between the candidate inputs and the response. The selection at each step is dependent on all previous selections. Therefore, the first selected input is the most important and it affects all the following selections. The number of steps can be determined by a simple Cp statistic. The result of LAR is a regression model as
y=w0+w1xj1+ . . . w8xju,
where xj1, . . . xju are the subset of inputs selected, and w0, . . . wju are the coefficients for the inputs. LAR is closely related to least absolute shrinkage and selection operator (Lasso), which minimizes the residual sum of squares, subject to a constraint on the l1 norm of regression coefficients, i.e.,
The l1 penalized regression forces most of the coefficients wj to become zero. Only the inputs with non-zero coefficients are selected for regression. These inputs are considered as factors really affecting the response.
A method for generating the overlay invariant network given the pair-wise invariant network will now be described in greater detail. The overlay invariants of the overlay invariant network are in a form of a regression model
xi=w0+w1xj
The task of extracting the overlay invariants includes discovering a set of measurement metrics or nodes {xj
The subnet representative selection process of block 520 (
Each pair-wise invariant contains a certain amount of error, and the error gets accumulated during propagation. Thus, increasing the number of propagation hops increases the amount of error that is introduced.
To minimize accumulated error, the representative system measurement node in the subnet should have as many immediate neighboring system measurement nodes as possible, so its estimated value through the overlay invariant can be propagated in one hop to as many non-representative system measurement nodes as possible.
In addition, the invariants between the representative system measurement nodes and the non-representative system measurement nodes should be as accurate as possible to minimize error accumulation. Since the accuracy of the pair-wise invariants is measured by the fitness score, the representative system measurement node should have the highest fitness scores with all other system measurement nodes within the subnet. This criteria is referred to herein as “most neighbors highest fitness score” (MNHF) rule. Based on the MNHF rule, the pseudocode of an algorithm or method for selecting the representative system measurement node for a subnet can include: for each node, calculate the summation of fitness scores fneighbor with all its immediate neighbors; pick the node with the largest fneighbor as the representative.
The representative system measurement nodes as well as all isolated nodes form a smaller metric set of measurement nodes that is used in block 530 of
The mRMR subset selection process of the mRLR process of block 540 (
For example, among 10 variables x1 . . . x10, suppose there are x2=x3+x4, then when x1 is considered as the response variable, a perfect multi-collinearity exists among the candidate inputs x2 . . . x10. Therefore, before applying LAR, a subset selection needs to be performed for two purposes: decreasing the size of candidate set to speed up the algorithm and breaking multi-collinearity.
Given a response variable, the criterion of subset selection is to find a set of measurement nodes which jointly have the largest dependency on the response variable. While this criterion is difficult to implement, the earlier mentioned mRMR process is used. The main idea of this process is ensuring that the selected subset has a high relevance with the response, but low redundancy inside itself. Instead of using mutual information, a fitness score is used as a metric for relevance and redundancy. The pseudocode for the mRMR-based process or algorithm is set forth below in Algorithm 1.
where f (.,.) is the fitness score between two measurement nodes. Overall, the mRMR process of Algorithm 1 selects one input at each step. At each step c, for each measurement node xj, the relevance (R1) between node xj and the response variable xi is defined as the fitness score f(xi, xj), and the redundancy (R2) will introduce to the selected set is defined as the mean of the fitness scores with previously selected inputs. The intuition for the redundancy metric is that if one measurement node has a high fitness score with previously selected inputs, the measurement node has a high linear relationship with these selected inputs and this measurement node could be represented by the existing selected inputs. At each step, the measurement maximizing R1-R2 is selected.
Using the mRMR process, the number of candidate inputs is reduced to get a smaller set of measurement nodes which is referred to herein as the mRMR set. Note that the mRMR set is not necessarily equal to the exact subset determining the response variable, but could be reasonably larger. The LAR process of the mRLR process of block 540 (
The LAR process of the mRLR process of block 540 (
As input for the mRLR process of Algorithm 1, only the subnet representative nodes obtained from the process of block 520 of
By using mRLR, on one hand, the search space is reduced dramatically through mRMR subset selection. On the other, the mRLR process is performed multiple times to explore more search space under the guidance of the previous search.
Due to system delay or unsynchronized data logging, the response variable x1 at time t may not only depend on other variables at time t, but also their previous values at t−1, t−2 etc. Algorithm 2 could be extended to incorporate such time dependency. At step 7, for each response x1(t), we originally feed LAR with the measurements at the same time t from sq, i.e., {j1(t) . . . xj2(t)}. When taking time dependency into consideration, we will include the independency into consideration, we will include the inputs from time t−d to t, where d is the maximum time lag for each input, i.e., we now feed LAR with {x1(t−d) . . . x1(t), . . . x2
The overlay invariants connect the originally separated subnets of the pair-wise invariant network together, enabling the intensity flow to propagate across the subnets. The pair-wise invariants and overlay invariants can now be used together for performing the capacity planning process of block 340 in
The capacity planning process includes two rules for selecting invariants, in decreasing priority: 1) available invariants are selected first; and 2) select invariants with the highest fitness score first.
In rule 1, where available invariants are selected first, an invariant is available if all its inputs are available, i.e., the value of the inputs are known. Following this rule, for two invariants λ1 and λ2, if all input values of λ1 are already known but some input values of λ2 need to be calculated from another invariant, invariant λ1 will be selected. From another perspective, this rule is equivalent to the shortest path first in invariant network.
In rule 2, where the highest fitness score is used first, for each response variable, if there are multiple available invariants, the invariant with the highest fitness score is selected because it generates the most accurate prediction.
The pseudocode for the two rule-based capacity planning process or algorithm is set forth below in Algorithm 3.
Starting from a set of available measurements as reachable nodes (this is an estimation given by operators, where for example, during Christmas the workload will be 150% of normal workload), the capacity planning process searches available pair-wise and overlay invariants to predict the value of their response variable, which then also become reachable and further propagate to other nodes. The process keeps on running until no new reachable nodes could be discovered.
The method of the present disclosure may be performed by an appropriately programmed computer, the configuration of which is well known in the art. An appropriate computer may be implemented, for example, using well known computer processors, memory units, storage devices, computer software, and other modules. A block diagram of a non-limiting embodiment of the computer is shown in
One skilled in the art will recognize that an implementation of an actual computer will contain other elements as well, and that
While exemplary drawings and specific embodiments have been described and illustrated herein, it is to be understood that that the scope of the present disclosure is not to be limited to the particular embodiments discussed. Thus, the embodiments shall be regarded as illustrative rather than restrictive, and it should be understood that variations may be made in those embodiments by persons skilled in the art without departing from the scope of the present invention as set forth in the claims that follow and their structural and functional equivalents.
This application claims the benefit of U.S. Provisional Application No. 61/243,755, filed Sep. 18, 2009, the entire disclosure of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6862624 | Colby et al. | Mar 2005 | B2 |
7113986 | Goldszmidt et al. | Sep 2006 | B2 |
7403988 | Blouin et al. | Jul 2008 | B1 |
7519705 | Papagiannaki et al. | Apr 2009 | B1 |
8046767 | Rolia et al. | Oct 2011 | B2 |
8224624 | Cherkasova et al. | Jul 2012 | B2 |
8543711 | Rolia et al. | Sep 2013 | B2 |
20020059237 | Kumagai et al. | May 2002 | A1 |
20050267702 | Shah et al. | Dec 2005 | A1 |
20110270646 | Prasanna et al. | Nov 2011 | A1 |
Entry |
---|
Arlitt et al., “Web Server Workload Characterization: The Search for Invariants (Extended Version)”, Mar. 15, 1996, p. 1-15. |
Number | Date | Country | |
---|---|---|---|
20110072130 A1 | Mar 2011 | US |
Number | Date | Country | |
---|---|---|---|
61243755 | Sep 2009 | US |