System and computer-implemented method for determining optimal combinations of elements having multiple dimensions, including determining the optimal number of destination servers for server consolidation, wherein existing servers are evaluated across multiple dimensions.
|
7. At least one non-transitory computer-readable medium storing computer-readable instructions that, when executed by one or more computing devices, cause at least one of the one or more computing devices to:
implement a magnitude classification model (mcm) that provides a plurality of mcm magnitude classifications corresponding to a plurality of distribution intervals;
assign, for each of a plurality of continuous values for a plurality of dimensions, each individual continuous value to one of the plurality of mcm magnitude classifications based on which of the plurality of distribution intervals includes the individual continuous value;
generate a combination matrix having a plurality of elements corresponding to the plurality of mcm magnitude classifications, the elements being presented in the combination matrix in a sorted combinational order, the sorted combinational order having element values descending from a first end of the combination matrix to a second end of the combination matrix;
remove each element assigned to the highest mcm magnitude classification and increment a count of packed combinations for each element removed;
resize the combination matrix to fit the remaining elements; and
iteratively combine the remaining elements within the combination matrix to determine the optimal combination of the remaining elements.
13. A method executed by one or more computing devices for determining optimal combinations of elements having values along multiple dimensions, the method comprising:
setting, by at least one of the one or more computing devices, threshold values for each dimension or common threshold values for all dimensions corresponding to a plurality of mcm magnitude classifications;
converting, by at least one of the one or more computing devices, continuous values of each dimension to be considered for packing into one of the plurality of mcm magnitude classifications using fuzzy logic;
generating, by at least one of the one or more computing devices, a sorted combination matrix having a plurality of elements corresponding to the plurality of mcm magnitude classifications, the elements being presented in the combination matrix in a sorted combinational order, the sorted combinational order having element values descending from a first end of the combination matrix to a second end of the combination matrix;
removing, by at least one of the one or more computing devices, each element assigned to the highest mcm magnitude classification and incrementing a count of packed combinations for each element removed;
resizing, by at least one of the one or more computing devices, the combination matrix to fit the remaining elements; and
iteratively combining, by at least one of the one or more computing devices, the remaining elements within the combination matrix to determine the optimal combination of the remaining elements.
15. An apparatus for determining optimal combinations of elements having multiple dimensions, the apparatus comprising:
one or more processors; and
one or more memories operatively coupled to at least one of the one or more processors and having instructions stored thereon that, when executed by at least one of the one or more processors, cause at least one of the one or more processors to:
implement a magnitude classification model (mcm) that provides a plurality of mcm magnitude classifications corresponding to a plurality of distribution intervals;
assign, for each of a plurality of continuous values for a plurality of dimensions, each individual continuous value to one of the plurality of mcm magnitude classifications based on which of the plurality of distribution intervals includes the individual continuous value;
generate a combination matrix having a plurality of elements corresponding to the plurality of mcm magnitude classifications, the elements being presented in the combination matrix in a sorted combinational order, the sorted combinational order having element values descending from a first end of the combination matrix to a second end of the combination matrix;
remove each element assigned to the highest mcm magnitude classification and increment a count of packed combinations for each element removed;
resize the combination matrix to fit the remaining elements; and
iteratively combine the remaining elements within the combination matrix to determine the optimal combination of the remaining elements.
1. A computer-implemented method executed by one or more computing devices for determining optimal combinations of elements having multiple dimensions, the method comprising:
implementing, by at least one of the one or more computing devices, a magnitude classification model (mcm) that provides a plurality of mcm magnitude classifications corresponding to a plurality of distribution intervals;
assigning, by at least one of the one or more computing devices, for each of a plurality of continuous values for a plurality of dimensions, each individual continuous value to one of the plurality of mcm magnitude classifications based on which of the plurality of distribution intervals includes the individual continuous value;
generating, by at least one of the one or more computing devices, a combination matrix having a plurality of elements corresponding to the plurality of mcm magnitude classifications, the elements being presented in the combination matrix in a sorted combinational order, the sorted combinational order having element values descending from a first end of the combination matrix to a second end of the combination matrix;
removing, by at least one of the one or more computing devices, each element assigned to the highest mcm magnitude classification and incrementing a count of packed combinations for each element removed;
resizing, by at least one of the one or more computing devices, the combination matrix to fit the remaining elements; and
iteratively combining, by at least one of the one or more computing devices, the remaining elements within the combination matrix to determine the optimal combination of the remaining elements.
2. The method of
determining whether the distribution interval associated with a combined continuous value resulting from a combination of an individual continuous value associated with a first element from the first end of the combination matrix with an individual continuous value associated with a second element from the second end of the combination matrix corresponds to the highest mcm magnitude classification, the individual continuous value associated with the first element and the individual continuous value associated with the second element being in the same dimension;
assigning the highest mcm magnitude classification to the first element based at least in part on a determination that the distribution interval associated with the combined continuous value exceeds the highest mcm magnitude classification;
combining the first element with the second element based at least in part on a determination that the distribution interval associated with the combined continuous value does not exceed the highest mcm magnitude classification; and
removing any elements from the combination matrix which have the highest mcm magnitude classification, and incrementing the count of packed combinations for each element removed.
4. The method of
5. The method of
6. The method of
8. The at least one non-transitory computer-readable medium of
determine whether the distribution interval associated with a combined continuous value resulting from a combination of an individual continuous value associated with a first element from the first end of the combination matrix with an individual continuous value associated with a second element from the second end of the combination matrix corresponds to the highest mcm magnitude classification, the individual continuous value associated with the first element and the individual continuous value associated with the second element being in the same dimension;
assign the highest mcm magnitude classification to the first element based at least in part on a determination that the distribution interval associated with the combined continuous value exceeds the highest mcm magnitude classification;
combine the first element with the second element based at least in part on a determination that the distribution interval associated with the combined continuous value does not exceed the highest mcm magnitude classification; and
remove any elements from the combination matrix which have the highest mcm magnitude classification, and incrementing the count of packed combinations for each element removed.
9. The at least one non-transitory computer-readable medium of
10. The at least one non-transitory computer-readable medium of
11. The at least one non-transitory computer-readable medium of
12. The at least one non-transitory computer-readable medium of
14. The method of
16. The apparatus of
determine whether the distribution interval associated with a combined continuous value resulting from a combination of an individual continuous value associated with a first element from the first end of the combination matrix with an individual continuous value associated with a second element from the second end of the combination matrix corresponds to the highest mcm magnitude classification, the individual continuous value associated with the first element and the individual continuous value associated with the second element being in the same dimension;
assign the highest mcm magnitude classification to the first element based at least in part on a determination that the distribution interval associated with the combined continuous value exceeds the highest mcm magnitude classification;
combine the first element with the second element based at least in part on a determination that the distribution interval associated with the combined continuous value does not exceed the highest mcm magnitude classification; and
remove any elements from the combination matrix which have the highest mcm magnitude classification, and incrementing the count of packed combinations for each element removed.
18. The apparatus of
19. The apparatus of
20. The apparatus of
|
This application claims priority to Indian Patent Application No. 1214/CHE/2011, filed Apr. 7, 2011, which is hereby incorporated by reference in its entirety.
With the increasing adoption of Service-oriented Architecture (SOA) and cloud computing technologies where Information Technology, including infrastructure, platforms and applications are delivered as services, there is an increasing use of the shared resource model. In such a model, computing and IT resources are shared across multiple applications. Accordingly, there is an increasing need for solutions that optimize the resource allocation. Power, cooling and real estate costs represent a significant portion of the overall cost in operating a cloud computing platform, service or datacenter. The reduction or optimization of resources associated with such costs creates a net benefit in total operating cost, reduces the need for expensive infrastructure and provides an opportunity to expand the platform. The challenge in consolidating such workloads is to minimize the number of physical servers while taking into consideration the resource needs across multiple dimensions. In this space, the dimensions include, but are not limited to, CPU, memory, data storage, I/O, networking bandwidth, network topology, and router utilizations—which are all subject to change in real-time dependent upon user needs and workloads.
Server consolidation methods aim to provide an efficient usage of computer server resources in order to reduce the total number of servers required for a particular software implementation, or a collection of software implementations. That is, server consolidation functions to address the problem of “server sprawl”. Server sprawl is understood in the art to refer to multiple under-utilized servers consuming more resources than is necessary to provide the functionality required by the software packages loaded thereupon.
Server consolidation may generally be classified into three stages: centralization, physical consolidation and data and application integration. Centralization involves moving servers to a common location. Physical consolidation involves moving a large number of existing servers to a small number of high-performance servers. Storage consolidation is also a kind of physical consolidation where disparate or related data and applications are integrated into a common database and common application. These classifications operate to reduce server under-utilization—typical levels of under-utilization in a non-consolidated environment may range from 15-20% of individual physical server capacity being unused.
A technique for physical consolidation, which is well known in the art, is the use of server virtualization technology. Virtualization enables multiple existing servers to be moved to share the resources of a single computer, or a dynamically selected grouping of computers. That is, software is used to divide one physical server into multiple isolated virtual environments or instances. Multiple methods of virtualization are known to those skilled in the art, e.g., hardware emulation, para-virtualization, OS-level virtualization, application level virtualization, etc. Regardless of the particular virtualization implementation method, the goal is to minimize the number of physical servers. This goal, minimizing the number of physical servers, competes directly with the twin goal of ensuring that sufficient resources are made available to avoid performance degradation. Put another way, sufficient resources are required to avoid degradation in performance, wherein the sum of resource utilization for virtual machines on a physical server (destination server) does not exceed the threshold limits prescribed for that particular destination server, while the number of destination servers is as small as possible to provide a cost benefit to the server consolidation process.
The optimization of destination servers may be viewed as a bin or vector packing problem. That is, items of different sizes must be packed into a minimum number of bins with a defined capacity. The basic bin packing problem is as follows: given N objects, each with a value vi, i=1, . . . , N, these objects must be packed in as few bins as possible such that Σνt of objects packed in the same bin does not exceed the bin's capacity. The bin packing problem may be understood in the server consolidation context as follows: objects for server consolidation are existing servers, object sizes are resource utilizations, bins are destination servers, and the bin capacity is the utilization threshold of the destination servers. Resource utilizations may include existing server CPU, disk and memory requirements. Where multiple resources (CPU, disk, memory, etc.) are being considered, the resources form multiple dimensions in the packing problem. The solutions to bin and vector packing problems are the same in the one-dimensional case. However, in multi-dimensional cases, the problem is considered as a vector packing problem.
A two-dimensional server packing problem may be formally understood as follows: Let ρc
There are several methods well known in the art to solve such multi-dimensional vector packing problems, for example, the First Fit Decreasing (FFD) algorithm. The FFD algorithm may be understood by the following pseudo code.
sort existing servers to {s1, ..., sn} in descending order;
m← 1; X1 ← { };
for i ← 1 to n do
for j ← 1 to m do
if packable (Xj, si) then
Xj ←Xj ∪{si};
break
fi
end for;
if j = m + 1 then
/* if fail to pack si, */
m ← m + 1;
/* a new server is added */
Xm ← {si}
/* to have si */
fi
end for
The FFD algorithm addresses the server packing problem by first receiving n existing servers and sorting them in descending order of utilizations of a certain resource. After the algorithm is executed, it produces server accommodations Xj (j=1, . . . , m), where m is the number of destination servers. The function packable (Xj, si) returns true if packing existing server si into destination server s′j satisfies the constraints (i.e., the utilization of s′j does not exceed a threshold for any resource); otherwise it returns false. FFD sequentially checks if all existing servers s1, . . . , sn can be packed into one of m current destination servers. FFD then packs si into a destination server first found to be able to accommodate it. If si cannot be packed into any current destination server, the (m+1)-th destination server is added to accommodate it. The complexity of this FFD algorithm is O(n2) because m is almost proportional to n.
A second algorithm for vector packing known in the art is the Least Loaded algorithm (LL). The LL algorithm may be understood by the following pseudo code.
sort existing servers to {s1, ..., sn} in descending order;
m←LB ({s1, ..., sn });
while true do
for j ← 1 to m do
Xj←{ } /* initialization */
end for;
for i←1 to n do
sort destination servers to {X1, ..., Xm} in ascending order;
for j←1 to m do
if packable (Xj, si) then
Xj←Xj∪{si};
break
fi
end for;
if j= m + 1 then /* If fail to pack si, a new server is added */
m ←m + 1;
break
fi
end for;
if i = n + 1 then /* all packed */
break
fi
end while
The LL algorithm attempts to balance the load between servers by assigning incoming jobs to the least-loaded server. In server packing, an existing server with a high utilization is packed into a server with low utilization. The function LB({s1, . . . , sn}) returns the theoretical lower bound for the number of destination servers that accommodate existing servers {s1, . . . , sn}. The lower bound is the smallest integer of numbers larger than the sum of the utilizations divided by a threshold. The lower bound for the CPU is
while that for the disk is
Function LB({s1, . . . , sn}) returns the larger integer of the two lower bounds.
There are two differences between LL and FFD. First, LL starts repacking after a new destination server is added when it has failed to pack an existing server into current m destination servers. This is aimed at balancing the load between a newly added destination server and the others. In contrast, FFD packs the existing server in question into a new destination server and continues to pack the remaining existing servers. LL initializes m to the lower bound to save time, even though we can also start with m=1. Second, LL sorts destination servers (which accommodate X1, . . . , Xm) in ascending order of utilizations each time before packing an existing server to pack it into a less-loaded destination server. The complexity of LL is O(d·n2 log n) where d is the difference between the lower bound and the final number m of destination servers.
The LL and FFD algorithms are limited in that only a single dimension is optimized at a time, i.e., neither LL nor FFD optimize multiple resources in a simultaneous manner. Further, because each dimension must first be considered independent of other dimensions, there is an inherent performance (time) cost to the optimization process.
There is a need in the art for a faster method of vector packing that is capable of handling multiple dimensions in a simultaneous manner. For example, in the field of server consolidation in virtualization environments, there is a specific need to be able to quickly determine the optimal server allocation arrangement. However, the optimal solution must be determined in a short enough time period such that changing workloads can be accommodated. Such environments may require thousands of existing servers to be consolidated to a much smaller number of destination servers in real-time or in advance of actual load balancing. Thus, speed in determining server consolidation may take priority over accuracy.
Various embodiments of the present invention will be described in detail with reference to the drawings. Reference to various embodiments does not limit the scope of the invention, which is limited only by scope of claims attached hereto. Additionally, any examples set forth in this specification are not intended to be limiting and merely set forth some of the many possible embodiments. Also, it is to be understood that the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including”, “comprising”, or “having” and variations thereof herein is meant to encompass the items listed thereafter and equivalents thereof as well as additional items.
The disclosed embodiments are a method of solving a vector packing problem having multiple dimensions. Stated another way, the embodiments determine optimal combinations of elements having values along multiple dimensions, comprising the conversion of continuous values of each dimension to be considered for packing into discrete values using various techniques known in the field of fuzzy logic, generating a sorted combination matrix of the elements to be packed (sorted by the values along each dimension), setting individual thresholds for the highest distribution interval in each dimension or a common threshold value for all dimension, and optimizing the matrix to determine the optimal packing.
The vector packing problem, as applied in the server consolidation context, may be understood to encompass existing servers as objects for server consolidation, resource utilizations as object sizes, destination servers as bins, and the utilizations thresholds of the destination servers as bin capacities. Object sizes include multiple dimensional values and may be understood as existing server CPU, disk, I/O, memory utilization and any other measurable requirement placed on an existing server or network arrangement by an application, process, user or hardware. The methodologies utilized in the prior art require an indeterminate amount of time to arrive at the optimal packing solution and are not suited to operating in a dynamic environment where user, hardware, and application workloads are in constant change. A solution is therefore required which provides solutions to the described vector packing problem in a predictable period of time.
TABLE 1
Name (Magnitude)
Distribution Interval
Full (F)
Greater than or equal to 75%,
but less than or equal to 100%
Large (L)
Greater than or equal to 50%,
but less than 75%
Medium (M)
Greater than or equal to 25%,
but less than 50%
Small (S)
Greater than or equal to 0%, but
less than 25%
The distribution intervals can be non-uniform. That is, defined threshold ranges may include the intervals 0-10%, 10-15%, 15-25%, etc. Such an arrangement of distribution intervals may be desirable, for example, where, based on historical data, it has been determined that there is a greater incidence of dimensional values under a particular magnitude. Accordingly, the MCM may be fine tuned to capture more realistic classifications and provide greater accuracy and granularity in the consolidation process 103. Table 2 provides an exemplary MCM having non-uniform distribution levels.
TABLE 2
Name (Magnitude)
Distribution Interval
A
Greater than or equal to 70%,
but less than or equal to 100%
B
Greater than or equal to 60%,
but less than 70%
C
Greater than or equal to 50%,
but less than 60%
D
Greater than or equal to 48%,
but less than 50%
E
Greater than or equal to 46%,
but less than 48%
F
Greater than or equal to 44%,
but less than 46%
G
Greater than or equal to 42%,
but less than 44%
H
Greater than or equal to 40%,
but less than 42%
I
Greater than or equal to 30%,
but less than 40%
J
Greater than or equal to 0%, but
less than 30%
In the instance of a single dimensional resource, i.e., a resource having only one attribute, the MCM will produce a simple classification of possible combinations. Referring to Table 1, the single dimension could only be classified as Full (F), Large (L), Medium (M) or Small (S), which may be represented as a one-dimensional array. In the instance of multiple dimensional resources, the number of possible combinations form a combination matrix 102. The generation of a combination matrix 102 is dependent on the number of dimensions of the resources and the number of intervals in the MCM.
In an embodiment, the mapping of each dimensional value to a magnitude classification is implemented by applying principles of fuzzy logic. Referring to
In yet another embodiment, the mapping of each dimensional value to a magnitude classification may be implemented by the following exemplary pseudo code. The following code considers only a single dimensional mapping (network utilization), but may be logically extended to include n number of dimensions.
new arrayList
for i ← 0 to numberExistingServers do
serverIntensityCombinationName=“”;
if (existingServer.Network = true) {
if (existingServer.NetworkUtilization > NetworkThreshold( )*.9){
serverIntensityCombinationName=
serverIntensityCombinationName+“A”; }
else if (existingServer.NetworkUtilization >
NetworkThreshold( )*.8 {
serverIntensityCombinationName=
serverIntensityCombinationName+“B” }
...
else if (existingServer.NetworkUtilization >
NetworkThreshold( )*.1 {
serverIntensityCombinationName=
serverIntensityCombinationName+“I” }
else serverIntensityCombinationName=
serverIntensityCombinationName+“J” }
end for
At Block 102, the combination matrix is generated, which is a simple matrix based on the number of combinations available in the MCM, defined above. The dimensions of the matrix are the number of possible combinations, defined by the number of dimensions and number of distribution intervals being considered. In the server consolidation context, the number of dimensions is the number of resource attributes being considered. The number of total combinations is mn, where m equals the number of distribution intervals and n equals the number of dimensions. For example, referring to Table 1, the simple case of four defined distribution intervals for a two-dimensional problem provides 42=16 total number of combinations. Accordingly, the dimensions of the combination matrix are mn. The multi-dimensional combinations are inserted into the combination matrix in descending order, i.e., in order of decreasing combinational magnitude as defined by the MCM. The combination matrix in this simple case (inserting all possible combinations for the purpose of explanation) is as follows:
Table 3 provides examples of how the alternative combination matrices may be sized.
TABLE 3
No. of Dimensions
No. of Intervals
Combination Matrix
2
2
2 × 2
2
3
3 × 3
2
4
4 × 4
2
10
10 × 10
3
2
2 × 2 × 2
3
3
3 × 3 × 3
3
10
10 × 10 × 10
n
M
mn
A feasibility table provides the rule set for possible combinations. That is, the feasibility table defines the constraints on dimensional value combinations under the defined MCM. Table 4 provides an exemplary feasibility table for the simple case described in Table 1.
TABLE 4
Combinations
Name (Magnitude)
Possible
Result
Full (F)
No combination
—
possible,
considered being at
highest elevation,
i.e., no capacity to
consolidate further.
Large (L)
May be combined
Large (L) + Small (S) =
with Small (S)
Full (F)
Medium (M)
May be combined
Medium (M) + Medium
with Medium (M)
(M) = Full (F)
May be combined
Medium (M) + Small (S) =
with Small (S)
Large (L)
Small (S)
May be combined
Small (S) + Large (L) =
with Large (L)
Full (F)
May be combined
Small (S) + Medium (M) =
with Medium (M)
Large (L)
May be combined
Small (S) + Small (S) =
with Small (S)
Medium (M)
Referring to
At initial step 301, all combination elements consisting of the top most magnitude or distribution interval of the MCM are removed. Such elements are considered as being completely full and cannot be packed any further. The matrix may be resized to fit only the remaining elements. In this example, all elements consisting a dimensional value “F”, i.e. the top most magnitude of Table 1, are removed. Accordingly, the resulting matrix may be described as:
Each combination element removed in 301 is added to the total count or total packed element combination 302. In the server consolidation context, the total count is representative of the number of destination servers. Accordingly, the current number of destination servers is 7.
The consolidation 303 of remaining elements is completed via an iterative process of combining the combination element(s) of the first cell of the matrix with the combination element(s) of the last cell of the matrix. In this example, the first element LL is added to the last element SS with a packed element combination of FF, as defined in the feasibility table, Table 4. If the packed element combination exceeds the threshold for the highest MCM classification or distribution interval defined in Table 1, then the first element is marked as equivalent to the highest classification and considered to be completely full and the next element is considered for consolidation. If, however, the packed element combination does not exceed the threshold for the highest MCM classification or distribution level, then the next to last added element is added to the packed element combination. This process continues until all combination elements have been optimized. In this example, the packed element combination FF is at the highest MCM classification under Table 1, and is marked as such and considered full. A subsequent consolidation iteration attempts to combine combination elements LM and SM, resulting again in a packed element combination of FF, which is full. Table 5 shows the possible iterations in this example.
TABLE 5
Iteration
Combination Result
1
LL + SS = FF (Full)
2
LM + SM = FF (Full)
3
LS + SL = FF (Full)
4
ML + MS = FF (Full)
5
MM (remainder, combinations
exhausted)
The counts of 302 and 303 are aggregated to provide the total packed combination count, i.e., total destination server count. In this example, the total is 12 destination servers. The following is exemplary pseudo code for the consolidation process 303.
existing servers {s1, ..., sm} having attributes {a1, ..., an}
MagnitudeCombination [ ] ← [s1.a1.a....an, s2.a1.a....an , ..., sm.a1.a....an]
existingServerCount ← m;
destinationServerCount ← 0;
for x ← 1 to m do
for y ← 1 to n do
if sx.an.Magnitude contains any attribute matching top MCM
Classification “A”
destinationServerCount = destinationServerCount + 1;
else
populate the MagnitudeCombination[ ] by increasing the count
of the respective combination
end for
for i ← 1 to MagnitudeCombination[ ].size
if (MagnitudeCombination[k].Count ! = 0)
for l ← (MagnitudeCombination[MagnitudeCombination.size − k]) to
(MagnitudeCombination[ ].size)
if (MagnitudeCombination[k].Count ! = 0
&& (MagnitudeCombination[l]) ! = 0
&& MagnitudeCombination[k] not equal to
MagnitudeCombination[l]))
if (MagnitudeCombination[k].Count ≧
MagnitudeCombination [l].Count)
destinationServerCount = destinationServerCount +
MagnitudeCombination[l].Count;
MagnitudeCombination[k].Count =
MagnitudeCombination[k].Count −
MagnitudeCombination[l].Count;
MagnitudeCombination[l].Count = 0;
end if
else
destinationServerCount = destinationServerCount +
MagnitudeCombination[k].Count;
MagnitudeCombination[l].Count =
MagnitudeCombination[l].Count −
MagnitudeCombination[k].Count;
MagnitudeCombinatino[k[.Count = 0;
end for
end for
The performance of the instant vector packing solution provides significant advances over the prior art. These improvements are in terms of time to completion and variable granularity, among others. The prior art evaluates each dimensional value independently of other dimensional values, resulting in slow performance and unpredictable time to completion. The disclosed embodiments 100 consider all dimensional values simultaneously and significantly outperforms the prior art, especially when considering large data sets. Referring now to
TABLE 6
No. Destination Servers/Time (ms)
No. Existing
Least
New MCM
Servers
First Fit
Loaded
Method
5,000
2,636/227 ms
2,652/1,081 ms
2,726/159 ms
10,000
5,200/542 ms
5,337/3,424 ms
5,469/194 ms
15,000
7,628/1,107 ms
7,894/7,615 ms
8,185/343 ms
20,000
10,106/1,726 ms
10,501/12,951 ms
10,952/404 ms
25,000
12,570/2,492 ms
13,116/20,422 ms
13,672/431 ms
30,000
15,031/3685 ms
15,641/31,157 ms
16,385/577 ms
35,000
17,597/5,282 ms
18,344/40,484 ms
19,124/637 ms
40,000
19,996/7,530 ms
20,919/53,962 ms
21,835/611 ms
45,000
22,453/8,064 ms
23,501/68,513 ms
24,630/656 ms
50,000
24,755/10,761 ms
25,997/87,634 ms
27,289/787 ms
In an another embodiment, the consolidation process 300 may include an additional step where the arrangement of the final packed combinations in the combination matrix, as well as the elements removed at step 301, are stored in a database, or other suitable structure known in the art, for retrieval or further processing. The arrangement of packed combinations referred to here are the combinations represented by the packed combination count, or destination servers.
Referring to
Application of the embodiments is not limited to the server consolidation context. Instead, it may be applied to any multi-dimensional vector packing problem as appropriate. The embodiments described herein may be implemented via any appropriate computing environment, as understood by those skilled in the art. Further, the embodiments, in the server consolidation context, may interface with other software, hardware or any other appropriate means for gathering, storing and retrieving resource utilization data. By non-limiting example, the disclosed embodiments may interface with a router or other network-monitoring platform or device 507 for gathering usage data for determining the appropriate MCM or threshold values to be used. By further example, the disclosed embodiments may provide a server, network monitoring device, or other device 508 known in the art a server consolidation determination, a server consolidation plan, or the arrangement of packed combinations to a third-party, including users, a central server, or a data center.
Doddavula, Shyam Kumar, Kaushik, Mudit, Jain, Akansha
Patent | Priority | Assignee | Title |
9749183, | Apr 07 2011 | Infosys Limited | System and method for determining optimal combinations of computer servers |
Patent | Priority | Assignee | Title |
4692876, | Oct 12 1984 | Hitachi, Ltd. | Automatic freight stacking system |
5050090, | Mar 30 1989 | R J REYNOLDS TOBACCO COMPANY, A CORP OF NJ | Object placement method and apparatus |
5473545, | Apr 10 1993 | Method for storing individual pieces | |
6832129, | Feb 26 2003 | Mitsubishi Electric Research Laboratories, Inc. | Method for packing rectangular strips |
7478176, | Sep 19 2003 | Intel Corporation | Managing peripheral device address space resources using a tunable bin-packing/knapsack algorithm |
7761548, | Oct 24 2005 | Accenture Global Services Limited | Dynamic server consolidation and rationalization modeling tool |
20060107087, | |||
20100005173, | |||
20110173327, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 19 2011 | Infosys Limited | (assignment on the face of the patent) | / | |||
Jun 16 2011 | Infosys Technologies Limited | Infosys Limited | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 027448 | /0064 | |
Jun 29 2011 | DODDAVULA, SHYAM KUMAR | Infosys Technologies Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 026846 | /0467 | |
Jun 29 2011 | KAUSHIK, MUDIT | Infosys Technologies Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 026846 | /0467 | |
Jun 29 2011 | JAIN, AKANSHA | Infosys Technologies Limited | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 026846 | /0467 |
Date | Maintenance Fee Events |
Jul 22 2015 | ASPN: Payor Number Assigned. |
May 16 2017 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jul 19 2021 | REM: Maintenance Fee Reminder Mailed. |
Jan 03 2022 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Nov 26 2016 | 4 years fee payment window open |
May 26 2017 | 6 months grace period start (w surcharge) |
Nov 26 2017 | patent expiry (for year 4) |
Nov 26 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Nov 26 2020 | 8 years fee payment window open |
May 26 2021 | 6 months grace period start (w surcharge) |
Nov 26 2021 | patent expiry (for year 8) |
Nov 26 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Nov 26 2024 | 12 years fee payment window open |
May 26 2025 | 6 months grace period start (w surcharge) |
Nov 26 2025 | patent expiry (for year 12) |
Nov 26 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |