CN104407925A - Dynamic resource distribution method - Google Patents
Dynamic resource distribution method Download PDFInfo
- Publication number
- CN104407925A CN104407925A CN201410758791.4A CN201410758791A CN104407925A CN 104407925 A CN104407925 A CN 104407925A CN 201410758791 A CN201410758791 A CN 201410758791A CN 104407925 A CN104407925 A CN 104407925A
- Authority
- CN
- China
- Prior art keywords
- virtual machine
- host
- virtual machines
- cpu
- ramvalues
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 49
- 238000013439 planning Methods 0.000 claims abstract description 33
- 238000013468 resource allocation Methods 0.000 claims description 38
- 238000009499 grossing Methods 0.000 claims description 12
- 230000006870 function Effects 0.000 claims description 9
- 230000007704 transition Effects 0.000 claims description 4
- 230000003203 everyday effect Effects 0.000 claims description 3
- 239000012634 fragment Substances 0.000 abstract description 13
- 238000013467 fragmentation Methods 0.000 description 9
- 238000006062 fragmentation reaction Methods 0.000 description 9
- 230000005012 migration Effects 0.000 description 4
- 238000013508 migration Methods 0.000 description 4
- 238000004364 calculation method Methods 0.000 description 3
- 238000012163 sequencing technique Methods 0.000 description 3
- 230000008859 change Effects 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000008713 feedback mechanism Effects 0.000 description 2
- 230000008901 benefit Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000002474 experimental method Methods 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
Landscapes
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
The invention discloses a dynamic resource distribution method. The method includes the steps of firstly, predicting the increment of each specification of virtual machines in the next time period according to the number of newly-added virtual machines in the recent n time periods; secondly, conducting resource distribution ratio planning on available resources in a system resource pool according to the prediction result, determining the distribution priority levels of all mainframes and all the virtual machines, and determining the specification and the number of the corresponding virtual machines distributed to each mainframe; thirdly, distributing the virtual machines for which a user applies to the corresponding mainframe according to the high-to-low priority level sequence of the mainframes and the resource distribution ratio planning when the user applies for the virtual machines; fourthly, executing the first step when the ratio of the total number of the distributed specifications of virtual machines to the total number of the specifications of the virtual machines in the resource distribution ratio planning is larger than the preset threshold value. By means of the method, resource fragments can be effectively reduced in the IaaS environment, and physical resources can be fully used.
Description
Technical Field
The invention relates to a resource planning technology, in particular to a dynamic resource allocation method.
Background
At present, many operators and large-scale enterprises construct their own Infrastructure as a service (IaaS) to allow consumers to obtain computer Infrastructure services by themselves through a network. Because the IaaS can take all IT resources as a large-scale resource pool and is uniformly managed by the cloud platform, how to improve the overall utilization rate of the IT assets and reduce the IT cost investment is very important for operators and enterprises.
In IaaS, the dynamic nature of resource allocation is high, and the possibility of generating a large amount of resource fragments is high. Resource fragmentation refers to small free resources scattered on the resource pool host, which are difficult to utilize and wasteful due to their small capacity. The amount of fragmentation in the resource pool is an important factor influencing the usage rate of the IT assets. When a general cloud management system allocates resources, a simple method is used to plan the use of the resources, so that the generation of fragments cannot be reduced, and finally, the total capacity of a resource pool is vacant, but a virtual machine with a specified specification cannot be deployed.
At present, most of the resource allocation methods used in the prior art are designed for achieving optimal resource load allocation and optimizing resource use performance, and few resource allocation methods are available for the purpose of reducing resource fragments. Even in the resource allocation method, in order to reduce resource fragmentation, planning is often performed only on the existing resource situation, and the influence of the dynamic resource change factor on the resource allocation effect is not considered.
Disclosure of Invention
In view of this, the present invention provides a dynamic resource allocation method, so as to effectively reduce resource fragmentation in an IaaS environment and achieve full utilization of physical resources.
The technical scheme of the invention is realized as follows:
a method of dynamic resource allocation, the method comprising:
A. predicting the increment of the virtual machine of each specification in the next time period according to the number of newly added virtual machines in the latest n time periods;
B. according to the prediction result, performing resource allocation ratio planning on available resources in a system resource pool, and determining allocation priority levels of each host and each virtual machine and specification and number of the virtual machines allocated on each host;
C. when a user applies for a virtual machine, the virtual machine applied by the user is distributed to the corresponding host according to the sequence of the priorities of the hosts from high to low and the resource distribution ratio plan;
D. and B, obtaining the specification of the virtual machine applied by the user and the total number of the virtual machines of the specification distributed in the current time period, and returning to the step A when the ratio of the total number of the distributed virtual machines of the specification to the total number of the virtual machines of the specification in the resource distribution ratio plan is larger than a preset threshold value.
Preferably, the specification of the virtual machine includes:
1 core 1G; 1 core 2G; 2 core 2G; 2, core 4G; 4 nuclear 4G; 4 nucleus 8G; 4, core 12G; 8 nuclear 8G and 8 nuclear 12G.
Preferably, the increment of the virtual machine of each specification in the next time period is predicted by using a quadratic exponential smoothing method.
Preferably, the virtual machine increment in the next time period is predicted using the formula as follows:
Fk+T=ak+bkT
wherein,
ak=2Sk(1)-Sk(2)
Sk(1)=αXk+(1-α)Sk-1(1)
Sk(2)=αSk+(1-α)Sk-1(2)
wherein, Fk+TIs the increment of the virtual machine in the k + T time period, T is the interval number from the k time period to the next time period, akAnd bkAre all parameters, Sk(1) And Sk(2) Respectively a first exponential smoothing value and a second exponential smoothing value, alpha is a smoothing constant and the value range is [0, 1%]。
Preferably, the value of α is 0.9.
Preferably, the performing resource allocation ratio planning on the available resources in the system resource pool according to the prediction result includes:
step B1, counting the number of available resources in the system resource pool and the distribution of the available resources on the host computer every day;
b2, sorting the hosts according to the statistical result from small to large in the number of available CPUs and setting the priority, wherein the priority of the host with the smaller number of CPUs is higher;
step B3, sorting the virtual machines with various specifications in the prediction result according to the sequence of the CPU number of the virtual machines from small to large, and forming a virtual machine list according to the sorting result;
step B4, determining the CPU value and the memory value of each virtual machine according to the CPU number and the memory size of the virtual machines, and setting the CPU capacity and the memory capacity for each host;
step B5, sequentially carrying out resource planning on each host from high priority to low priority; in the resource planning of each host, traversing each virtual machine in the virtual machine list according to the sequence of the CPU number of the virtual machine from small to large, allocating the virtual machine which enables the total value of the current host to be maximum to the current host, and deleting the allocated virtual machine from the virtual machine list.
Preferably, the host is resource-programmed using the state transition equation as follows:
fcpu[i]=max{fcpu[i-1][cpuValues][ramValues],fcpu[i][cpuValues-cpu[i]][ramValues-ram[i]]+cpu[i]};
fram[i]=max{fram[i-1][cpuValues][ramValues],fcpu[i][cpuValues-cpu[i]][ramValues-ram[i]]+ram[i]};
wherein, fcpu [ i ] represents the sum of the number of CPUs of the virtual machines distributed in the host when the ith virtual machine is distributed to the host; fram [ i ] represents the sum of the memory sizes of the virtual machines allocated in the host when the ith virtual machine is allocated to the host; the cpuValues represents a host with the capacity of the cpu being the cpuValues; ramValues represent a host with the memory capacity of ramValues; the function fcpu [ i-1] [ cpuValues ] [ ramValues ] represents the (i-1) th virtual machine, and the obtained cpu value is obtained when the cpu value is put into the host with the cpu capacity being cpuValues and the memory capacity being ramValues; the function fram [ i-1] [ cpuValues ] [ ramValues ] represents the i-1 st virtual machine, and the obtained memory value is obtained when the function fram [ i-1] [ cpuValues ] [ ramValues ] is placed in a host with the cpu capacity being cpuValues and the memory capacity being ramValues.
Preferably, the threshold is 90%.
As can be seen from the above, in the dynamic resource allocation method of the present invention, since the resource demand prediction is combined with the resource planning, the secondary smoothness index algorithm closer to the actual situation is used to predict the resource demand in a short period, so that the resource allocation ratio planning is more predictive, thereby reducing unnecessary virtual machine migration, effectively reducing physical resource fragments in a cloud environment, satisfying the resource requests of all virtual machines as much as possible, accommodating as many virtual machines as possible, thereby improving the utilization rate of IT assets, and reducing IT cost investment; in addition, the method provided by the invention can predict and plan the resource demand again in time at the required moment through a dynamic feedback mechanism, so that the resource allocation ratio planning can be close to the actual situation as much as possible with the minimum calculation cost to meet the requirements of customers; in addition, the method provided by the invention is closer to the IaaS characteristic, and can perform double sequencing on the host and the virtual machine, so that the IaaS environment of any scale can be supported, and the applicability is very wide.
Drawings
Fig. 1 is a flowchart illustrating a dynamic resource allocation method according to an embodiment of the present invention.
FIG. 2 is a diagram illustrating a comparison of predicted results according to an embodiment of the present invention.
Detailed Description
In order to make the objects, technical solutions and advantages of the present invention more apparent, the present invention is further described in detail below with reference to the accompanying drawings and examples.
The increment of the number of virtual machines in each time period in IaaS can be regarded as a group of time series. Generally, the number of virtual machines applied by a user in a short period is not random and is supported by a demand background, and the demand background is generally stable. It is thus foreseen that the virtual machine increment within a certain time period in the short term may be regarded as a continuation of the historical value of the most recent time period. Therefore, the increment of the virtual machine in the next time period can be predicted according to the change trend of the increment of the virtual machine in the short time period. If the increment of the virtual machine can be accurately predicted, the allocation scheme of the resource pool can be well planned in advance according to the predicted value, so that the generation of resource fragments is reduced as much as possible under the condition of no virtual machine migration adjustment.
However, in an actual application environment, even under a substantially stable demand background, the number of virtual machines requested by a user may vary, and thus the increment of the number of virtual machines in a certain period of time may be different from the predicted value. For example, when the accumulated increment of a virtual machine of a certain specification in a certain time period has reached a predicted value, but a user may continue to apply for the virtual machine of the specification, so that the original resource allocation rule cannot be used continuously, at this time, the increment of the virtual machine of a different specification in the next time period needs to be predicted again, and the resource in the resource pool needs to be planned and allocated again. Therefore, in order to reflect the requirement of the user for applying the virtual machine more truly, in the technical scheme of the invention, the resource planning and allocation rule needs to be set in the future time according to the actual situation of the user application and when to adjust, so that the aims of reducing physical resource fragments and accommodating as many virtual machines as possible can be achieved with the minimum calculation cost.
Therefore, in the technical solution of the present invention, a dynamic resource allocation method is provided.
Fig. 1 is a flowchart illustrating a dynamic resource allocation method according to an embodiment of the present invention. As shown in fig. 1, the dynamic resource allocation method in the embodiment of the present invention mainly includes the following steps:
and 11, predicting the increment of the virtual machine of each specification in the next time period according to the number of the newly added virtual machines in the latest n time periods.
In the existing practical application environment, when a user applies for a virtual machine, the specification of the optional virtual machine is determined.
For example, in an embodiment of the present invention, the specification of the virtual machine includes: 1 core 1G; 1 core 2G; 2 core 2G; 2, core 4G; 4 nuclear 4G; 4 nucleus 8G; 4, core 12G; 8 specifications such as 8-core 8G and 8-core 12G.
Wherein, 1 core 1G indicates that the number of CPUs of the virtual machine is 1 (i.e., 1 core), the memory size is 1G, and so on.
According to actual experience and the use habit of a user, the increment of the number of the virtual machines in each time period has a certain rule in a short time, so that in the technical scheme of the invention, the request condition of the future virtual machines can be predicted through historical data (namely the number of newly added virtual machines in the latest n time periods). In addition, the method avoids that a certain user deletes a certain specification of virtual machines after applying for the same in a large amount due to user operation errors, and therefore prediction accuracy is affected. Therefore, in the technical scheme of the invention, the increment of the number of the virtual machines with different specifications in a time period is used as a prediction target.
With the rapid development of cloud computing technology, the demand of users on virtual machines is increasing. In the long term, the time series curve of the number of the user virtual machine applications tends to increase, and in the short term, the time series curve fluctuates slightly, so that the time series curve is a linear time series which generally tends to increase. Therefore, after many experiments and comparisons, in the preferred embodiment of the present invention, the increment of each specification of virtual machine in the next time period will be predicted using quadratic exponential smoothing to describe the linear growth trend closer to the actual situation.
Specifically, for each specification of virtual machine, the virtual machine increment in the next time period can be predicted using the formula as follows:
Fk+T=ak+bkT
wherein, Fk+TIs the increment (i.e. predicted value) of the virtual machine in the k + T time period, and T is the time period from the k time period to the next timeNumber of intervals of segments (i.e. prediction period), akAnd bkAre all parameters, and have:
ak=2Sk(1)-Sk(2)
Sk(1)=αXk+(1-α)Sk-1(1)
Sk(2)=αSk+(1-α)Sk-1(2)
wherein S isk(1) And Sk(2) Respectively a first exponential smoothing value and a second exponential smoothing value, alpha is a smoothing constant and the value range is [0, 1%]。
In the technical scheme of the invention, the value of the alpha can be preset according to the actual application requirement. For example, in the preferred embodiment of the present invention, the value of α may be 0.9.
Through the method, the increment of the virtual machine of each specification in the next time period can be predicted respectively.
The above-described method can be verified by a practical example. FIG. 2 is a diagram illustrating a comparison of predicted results according to an embodiment of the present invention. As shown in fig. 2, in this embodiment, the following history data (i.e. the number of newly added virtual machines in the latest n time periods) is adopted:
arr=[0;6;17;36;56;78;103;116;126;134;140;144;146;144;138;130;128;127;130;139;148;132;156;167;178;189;190]
the historical data has a total of 27 data, that is, the number of newly added virtual machines in the last 27 time periods of a virtual machine of a certain specification forms a group of time series, such as the original data curve shown in fig. 2. From the above history data, after prediction using the prediction method of the present invention, a prediction result curve as shown in fig. 2 is obtained.
As can be seen from fig. 2, the prediction result obtained after the prediction is performed by using the above method is relatively accurate, and when the trend of the original data curve changes, the response of the prediction result curve is very rapid.
In the technical scheme of the invention, the length of each time period can be preset according to the actual application requirement. For example, in a preferred embodiment of the present invention, the length of each time period is: 1 month or other length of time.
In the technical scheme of the invention, the value of n can be preset according to the actual application requirement. For example, in the preferred embodiment of the present invention, the value of n may be 15.
In addition, preferably, in an embodiment of the present invention, before the step 11, the method may further include:
reading the number of newly-added virtual machines of each specification in the latest n time periods from the virtual machine table;
the virtual machine table stores the number of newly added virtual machines of various specifications in each time period.
Preferably, in an embodiment of the present invention, the number of newly added virtual machines is a difference between the number of virtual machines newly applied by the user and the number of destroyed virtual machines in the current time period.
Preferably, in an embodiment of the present invention, the virtual machine table is stored in the cloudstock cloud platform.
And step 12, performing resource allocation ratio planning on available resources in the system resource pool according to the prediction result, and determining allocation priority levels of each host and each virtual machine, and specifications and number of the virtual machines allocated on each host.
In the technical scheme of the invention, the steps are as follows: by using the prediction result in step 11, how to plan and allocate the existing idle resources (i.e., available resources) in the system under the predicted new number of virtual machines of each specification can achieve the purposes of avoiding migration, reducing resource fragments, and satisfying resource requests of all virtual machines.
The resource allocation ratio planning refers to reasonably planning the residual resources (CPU and memory) of the physical machines in the resource pool, so that the resources on each host can be maximally utilized, and resource fragments are reduced as much as possible.
The more resources a host has occupied, the more fragmentation is likely to occur. Therefore, in the technical scheme of the invention, the resources of the host with less remaining available resources should be allocated first, so that the remaining hosts are ensured to be the hosts with more remaining resources, namely the hosts which are relatively difficult to generate fragments; in addition, the virtual machines occupying less resources are considered, so that the flexibility of resource allocation is higher, and resource fragments are favorably filled. Therefore, in order to ensure that the virtual machine allocation can fully utilize the resources in the system, in the technical scheme of the invention, the resources are allocated to the virtual machine with a large specification first. In summary, in the technical solution of the present invention, the planning and allocation of system resources should follow two rules: the rest hosts with less available resources are planned first, and the virtual machines with larger specifications are allocated first.
In the technical scheme of the invention, various modes can be used for carrying out resource allocation proportioning planning on available resources in a system resource pool. The technical solution of the present invention will be described below by taking one of the embodiments as an example.
For example, in an embodiment of the present invention, preferably, the performing resource allocation ratio planning on available resources in the system resource pool according to the prediction result includes:
and step 121, counting the number of the available resources in the system resource pool and the distribution of the available resources on the host computer every day.
And step 122, sequencing the hosts according to the statistical result from small to large available CPU quantity and setting the priority, wherein the priority of the host with the smaller CPU quantity is higher.
And step 123, sorting the virtual machines with various specifications in the prediction result according to the sequence of the CPU number of the virtual machine from small to large, and forming a virtual machine list according to the sorting result.
Step 124, determining the CPU value and the memory value of each virtual machine according to the CPU number and the memory size of the virtual machine, and setting the CPU capacity and the memory capacity for each host.
In the technical scheme of the invention, two values can be set for each virtual machine: CPU value and memory value. The value of the CPU value is the number of the CPUs of the virtual machine, and the value of the memory value is the size of the memory of the virtual machine. For example, the CPU value and memory value of the ith virtual machine are CPU [ i ] and ram [ i ], respectively.
In addition, in the technical scheme of the invention, two capacities can be set for each host: CPU capacity and memory capacity. Wherein the value of the CPU capacity represents the sum of the number of CPUs of the virtual machines allocated in the host, and the value of the memory value represents the sum of the memory sizes of the virtual machines allocated in the host.
Step 125, sequentially performing resource planning on each host from high priority to low priority; in the resource planning of each host, traversing each virtual machine in the virtual machine list according to the sequence of the CPU number of the virtual machine from small to large, allocating the virtual machine which enables the total value of the current host to be maximum to the current host, and deleting the allocated virtual machine from the virtual machine list.
Preferably, in an embodiment of the present invention, the host may be resource-programmed using the state transition equation as follows:
fcpu[i]=max{fcpu[i-1][cpuValues][ramValues],fcpu[i][cpuValues-cpu[i]][ramValues-ram[i]]+cpu[i]};
fram[i]=max{fram[i-1][cpuValues][ramValues],fcpu[i][cpuValues-cpu[i]][ramValues-ram[i]]+ram[i]}。
wherein, fcpu [ i ] represents the sum of the number of CPUs of the virtual machines distributed in the host when the ith virtual machine is distributed to the host; fram [ i ] represents the sum of the memory sizes of the virtual machines allocated in the host when the ith virtual machine is allocated to the host; the cpuValues represents a host with the capacity of the cpu being the cpuValues; ramValues represent a host with the memory capacity of ramValues; the function fcpu [ i-1] [ cpuValues ] [ ramValues ] represents the (i-1) th virtual machine, and the obtained cpu value is obtained when the cpu value is put into the host with the cpu capacity being cpuValues and the memory capacity being ramValues; the function fram [ i-1] [ cpuValues ] [ ramValues ] represents the i-1 st virtual machine, and the obtained memory value is obtained when the function fram [ i-1] [ cpuValues ] [ ramValues ] is placed in a host with the cpu capacity being cpuValues and the memory capacity being ramValues.
According to the state transition equation, if the ith virtual machine predicted to be created is not placed, placing the i-1 virtual machines predicted to be created into the host with CPU resources of cpuValues and memory resources of ramValues, wherein the CPU and the memory can reach the maximum value; if the ith virtual machine is placed, the method is converted into the maximum value which can be reached by the CPU and the memory in the host machine with CPU resources of CPU values-CPU [ i ] and memory resources of ramvalue-ram [ i ] in the previous i-1 virtual machines.
Therefore, in this step, the resource planning is performed for each host in turn. In each resource planning, each virtual machine in the virtual machine list is traversed from small to large, and whether the total value of the CPU and the RAM of the current host is larger than that of the previous virtual machine allocated to the current host is calculated if the virtual machine is allocated to the current host. After one round of comparison, recording the maximum total value when the current host is allocated with the virtual machine in the traversal process, and selecting the virtual machine to be allocated to the current host. When the current host is full (namely the residual resource is 0 or the residual resource cannot be reallocated to any virtual machine in the virtual machine list), finding out the virtual machine list allocated to the host according to the previous record, deleting the virtual machines allocated to the current host from the virtual machine list to obtain a new virtual machine list, and then traversing the next host again until all the hosts are processed completely.
Through the steps 121-125, the specification and number of the virtual machines allocated to each host can be determined, and resource allocation ratio planning on the available resources in the system resource pool is completed.
And step 13, when the user applies for the virtual machine, allocating the virtual machine applied by the user to the corresponding host according to the sequence of the priorities of the hosts from high to low and the resource allocation ratio plan.
Step 14, obtaining the specification of the virtual machine requested by the user and the total number of the virtual machines of the specification already allocated in the current time period, and returning to the step 11 when the ratio of the total number of the virtual machines of the specification allocated to the total number of the virtual machines of the specification in the resource allocation ratio plan is greater than a preset threshold value.
In the technical scheme of the invention, the threshold value can be preset according to the actual application requirement. For example, preferably, in the embodiment of the present invention, the threshold may be 90%.
In the technical solution of the present invention, after completing the resource allocation plan in step 12, when the user applies for the virtual machine, the virtual machine applied by the user can be placed on the corresponding host according to the resource allocation plan formulated in step 12 and according to the order of the priorities of the hosts from high to low. Meanwhile, whether the number of the allocated virtual machines of the specification is close to the upper limit or not is judged, namely whether the total number of the allocated virtual machines of the specification is larger than a preset threshold value or not is judged.
For example, when the ratio of the number of existing virtual machines of the specification to the number of virtual machines capable of accommodating the specification in the resource pool planned according to the resource allocation plan exceeds a certain preset threshold, it indicates that if the virtual machines of the specification are continuously allocated according to the previous resource allocation plan, there are no available resources, which may result in that the applied virtual machines cannot be deployed. Therefore, the resource allocation policy of the resource pool needs to be adjusted again. Furthermore, if the adjustment is needed, it can be determined whether the physical resources are insufficient, and if the resources are actually insufficient, the administrator needs to be informed; otherwise, returning to the step 12, planning and allocating the resource pool, making a new allocation strategy, updating the original allocation strategy into the adjusted virtual machine allocation strategy, and waiting for the next user request.
Through the steps 11-14, resource fragments are effectively reduced in the IaaS environment, and the full utilization of physical resources is realized.
For example, the methods in the prior art can be compared to the above methods provided in the present invention:
the existing 5 hosts in the IaaS environment are set, and the remaining available resources in each host are respectively as follows:
5 nuclear 10G, 6 nuclear 10G, 7 nuclear 10G, 8 nuclear 10G.
The number of virtual machines required to be allocated is 20, and the number of virtual machines of each specification is as follows:
specification of virtual machine | 1 core 1G | 1 nuclear 2G | 2 nuclear 2G | 2 nuclear 4G | |
Number of virtual machines | 4 tables | 3 tables | 6 tables | 7 tables | In total: 20 stations |
If the prior art method is used, the final random assignment result is as follows:
as shown in the above table, a total of 18 virtual machines are deployed, and the remaining two 2-core 4G virtual machines cannot be deployed. At this time, the sum of the remaining resources of the host can completely satisfy the two virtual machines, but each host does not satisfy the requirements, and the remaining two virtual machines cannot be deployed. At this time, the fragmentation rate of the system resources is: 14.7% of CPU, RAM: 16 percent.
If the method provided by the invention is used, the following distribution results can be obtained:
as shown in the above table, all of the 20 virtual machines are deployed, the sum of the remaining resources of the host is 1 core 0G, and the fragmentation rate of the system resources is: 2.94 percent of CPU and 0 percent of RAM.
Comparing the two results, the resource fragmentation generated by the virtual machine allocation according to the method provided by the invention is reduced by about 15% compared with the method in the prior art, and is far lower than the resource fragmentation rate in the method in the prior art.
In summary, in the dynamic resource allocation method, due to the combination of resource demand prediction and resource planning, the secondary smoothness index algorithm closer to the actual situation is used for predicting the resource demand in a short period, so that the resource allocation ratio planning is more predictive, unnecessary virtual machine migration is reduced, physical resource fragments in a cloud environment are effectively reduced, resource requests of all virtual machines are met as much as possible, and as many virtual machines as possible are accommodated, so that the utilization rate of IT assets is improved, and the IT cost input is reduced; in addition, the method provided by the invention can predict and plan the resource demand again in time at the required moment through a dynamic feedback mechanism, so that the resource allocation ratio planning can be close to the actual situation as much as possible with the minimum calculation cost to meet the requirements of customers; in addition, the method provided by the invention is closer to the IaaS characteristic, and can perform double sequencing on the host and the virtual machine, so that the IaaS environment of any scale can be supported, and the applicability is very wide.
The above description is only for the purpose of illustrating the preferred embodiments of the present invention and is not to be construed as limiting the invention, and any modifications, equivalents, improvements and the like made within the spirit and principle of the present invention should be included in the scope of the present invention.
Claims (8)
1. A method for dynamic resource allocation, the method comprising:
A. predicting the increment of the virtual machine of each specification in the next time period according to the number of newly added virtual machines in the latest n time periods;
B. according to the prediction result, performing resource allocation ratio planning on available resources in a system resource pool, and determining allocation priority levels of each host and each virtual machine and specification and number of the virtual machines allocated on each host;
C. when a user applies for a virtual machine, the virtual machine applied by the user is distributed to the corresponding host according to the sequence of the priorities of the hosts from high to low and the resource distribution ratio plan;
D. and B, obtaining the specification of the virtual machine applied by the user and the total number of the virtual machines of the specification distributed in the current time period, and returning to the step A when the ratio of the total number of the distributed virtual machines of the specification to the total number of the virtual machines of the specification in the resource distribution ratio plan is larger than a preset threshold value.
2. The method of claim 1, wherein the specification of the virtual machine comprises:
1 core 1G; 1 core 2G; 2 core 2G; 2, core 4G; 4 nuclear 4G; 4 nucleus 8G; 4, core 12G; 8 nuclear 8G and 8 nuclear 12G.
3. The method of claim 1, wherein:
and predicting the increment of the virtual machine of each specification in the next time period by using a quadratic exponential smoothing method.
4. The method of claim 3, wherein the virtual machine delta in the next time period is predicted using the formula:
Fk+T=ak+bkT
wherein,
ak=2Sk(1)-Sk(2)
Sk(1)=αXk+(1-α)Sk-1(1)
Sk(2)=αSk+(1-α)Sk-1(2)
wherein, Fk+TIs the increment of the virtual machine in the k + T time period, T is the interval number from the k time period to the next time period, akAnd bkAre all parameters, Sk(1) And Sk(2) Respectively a first exponential smoothing value and a second exponential smoothing value, alpha is a smoothing constant and the value range is [0, 1%]。
5. The method of claim 4, wherein:
the value of α is 0.9.
6. The method of claim 1, wherein the performing resource allocation ratio planning on available resources in a system resource pool according to the prediction result comprises:
step B1, counting the number of available resources in the system resource pool and the distribution of the available resources on the host computer every day;
b2, sorting the hosts according to the statistical result from small to large in the number of available CPUs and setting the priority, wherein the priority of the host with the smaller number of CPUs is higher;
step B3, sorting the virtual machines with various specifications in the prediction result according to the sequence of the CPU number of the virtual machines from small to large, and forming a virtual machine list according to the sorting result;
step B4, determining the CPU value and the memory value of each virtual machine according to the CPU number and the memory size of the virtual machines, and setting the CPU capacity and the memory capacity for each host;
step B5, sequentially carrying out resource planning on each host from high priority to low priority; in the resource planning of each host, traversing each virtual machine in the virtual machine list according to the sequence of the CPU number of the virtual machine from small to large, allocating the virtual machine which enables the total value of the current host to be maximum to the current host, and deleting the allocated virtual machine from the virtual machine list.
7. The method of claim 6, wherein resource planning is performed for the host using a state transition equation as follows:
fcpu[i]=max{fcpu[i-1][cpuValues][ramValues],fcpu[i][cpuValues-cpu[i]][ramValues-ram[i]]+cpu[i]};
fram[i]=max{fram[i-1][cpuValues][ramValues],fcpu[i][cpuValues-cpu[i]][ramValues-ram[i]]+ram[i]};
wherein, fcpu [ i ] represents the sum of the number of CPUs of the virtual machines distributed in the host when the ith virtual machine is distributed to the host; fram [ i ] represents the sum of the memory sizes of the virtual machines allocated in the host when the ith virtual machine is allocated to the host; the cpuValues represents a host with the capacity of the cpu being the cpuValues; ramValues represent a host with the memory capacity of ramValues; the function fcpu [ i-1] [ cpuValues ] [ ramValues ] represents the (i-1) th virtual machine, and the obtained cpu value is obtained when the cpu value is put into the host with the cpu capacity being cpuValues and the memory capacity being ramValues; the function fram [ i-1] [ cpuValues ] [ ramValues ] represents the i-1 st virtual machine, and the obtained memory value is obtained when the function fram [ i-1] [ cpuValues ] [ ramValues ] is placed in a host with the cpu capacity being cpuValues and the memory capacity being ramValues.
8. The method of claim 1, wherein:
the threshold is 90%.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410758791.4A CN104407925A (en) | 2014-12-10 | 2014-12-10 | Dynamic resource distribution method |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410758791.4A CN104407925A (en) | 2014-12-10 | 2014-12-10 | Dynamic resource distribution method |
Publications (1)
Publication Number | Publication Date |
---|---|
CN104407925A true CN104407925A (en) | 2015-03-11 |
Family
ID=52645558
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201410758791.4A Pending CN104407925A (en) | 2014-12-10 | 2014-12-10 | Dynamic resource distribution method |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN104407925A (en) |
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105743818A (en) * | 2016-02-03 | 2016-07-06 | 国网智能电网研究院 | Distribution method |
CN105912436A (en) * | 2015-09-17 | 2016-08-31 | 乐视网信息技术(北京)股份有限公司 | Method and device for predicting system computing resource based on exponential smoothing prediction |
CN107391233A (en) * | 2017-08-09 | 2017-11-24 | 郑州云海信息技术有限公司 | A kind of virtual machine migration method and system |
CN107391229A (en) * | 2017-07-26 | 2017-11-24 | 郑州云海信息技术有限公司 | A kind of cluster based on vmware virtualizations fills up method and device |
CN108028804A (en) * | 2015-07-10 | 2018-05-11 | 国际商业机器公司 | The management of virtual machine in virtual computation environmental based on structure limitation |
CN108122062A (en) * | 2016-11-30 | 2018-06-05 | 阿里巴巴集团控股有限公司 | The distribution of resource and the method and apparatus for establishing the assessment models of resource in product, product set in product set |
CN108459905A (en) * | 2017-02-17 | 2018-08-28 | 华为技术有限公司 | Resource pool method for planning capacity and server |
CN108829520A (en) * | 2017-06-20 | 2018-11-16 | 成都虫洞奇迹科技有限公司 | Server resource distribution method and device under a kind of cloud environment |
CN109033468A (en) * | 2018-08-31 | 2018-12-18 | 阿里巴巴集团控股有限公司 | The processing method and processing device of resource change |
CN109062683A (en) * | 2018-06-29 | 2018-12-21 | 深圳信息职业技术学院 | The method, apparatus and computer readable storage medium of host resource distribution |
CN109871336A (en) * | 2019-01-14 | 2019-06-11 | 珠海金山网络游戏科技有限公司 | A kind of dynamic buffering method of adjustment and system |
CN110187975A (en) * | 2019-06-04 | 2019-08-30 | 成都申威科技有限责任公司 | A kind of processor node distribution calculation method, storage medium and terminal device based on LBM |
CN110350609A (en) * | 2018-04-08 | 2019-10-18 | 北京京东尚科信息技术有限公司 | The charging management method and system of AGV, equipment and storage medium |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090235268A1 (en) * | 2008-03-17 | 2009-09-17 | David Isaiah Seidman | Capacity planning based on resource utilization as a function of workload |
WO2013123650A1 (en) * | 2012-02-22 | 2013-08-29 | 华为技术有限公司 | Method for virtual machine assignment and device for virtual machine assignment |
-
2014
- 2014-12-10 CN CN201410758791.4A patent/CN104407925A/en active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090235268A1 (en) * | 2008-03-17 | 2009-09-17 | David Isaiah Seidman | Capacity planning based on resource utilization as a function of workload |
WO2013123650A1 (en) * | 2012-02-22 | 2013-08-29 | 华为技术有限公司 | Method for virtual machine assignment and device for virtual machine assignment |
CN103548324A (en) * | 2012-02-22 | 2014-01-29 | 华为技术有限公司 | Method for virtual machine assignment and device for virtual machine assignment |
Non-Patent Citations (2)
Title |
---|
张婧: "《面向云计算运营管理的资源预测模型》", 《中国优秀硕士学位论文全文数据库》 * |
米海波,王怀民,尹刚,史殿习,周扬帆,袁霖: "《一种面向虚拟化数字中心资源按需重配置方法》", 《软件学报》 * |
Cited By (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108028804A (en) * | 2015-07-10 | 2018-05-11 | 国际商业机器公司 | The management of virtual machine in virtual computation environmental based on structure limitation |
CN105912436A (en) * | 2015-09-17 | 2016-08-31 | 乐视网信息技术(北京)股份有限公司 | Method and device for predicting system computing resource based on exponential smoothing prediction |
CN105743818A (en) * | 2016-02-03 | 2016-07-06 | 国网智能电网研究院 | Distribution method |
CN108122062B (en) * | 2016-11-30 | 2021-11-26 | 阿里巴巴集团控股有限公司 | Method and device for allocating resources in product set and establishing product and evaluation model of resources in product set |
CN108122062A (en) * | 2016-11-30 | 2018-06-05 | 阿里巴巴集团控股有限公司 | The distribution of resource and the method and apparatus for establishing the assessment models of resource in product, product set in product set |
CN108459905A (en) * | 2017-02-17 | 2018-08-28 | 华为技术有限公司 | Resource pool method for planning capacity and server |
CN108459905B (en) * | 2017-02-17 | 2022-01-14 | 华为技术有限公司 | Resource pool capacity planning method and server |
CN108829520A (en) * | 2017-06-20 | 2018-11-16 | 成都虫洞奇迹科技有限公司 | Server resource distribution method and device under a kind of cloud environment |
CN107391229A (en) * | 2017-07-26 | 2017-11-24 | 郑州云海信息技术有限公司 | A kind of cluster based on vmware virtualizations fills up method and device |
CN107391229B (en) * | 2017-07-26 | 2020-09-08 | 郑州云海信息技术有限公司 | Cluster filling method and device based on vmware virtualization |
CN107391233A (en) * | 2017-08-09 | 2017-11-24 | 郑州云海信息技术有限公司 | A kind of virtual machine migration method and system |
CN110350609A (en) * | 2018-04-08 | 2019-10-18 | 北京京东尚科信息技术有限公司 | The charging management method and system of AGV, equipment and storage medium |
CN109062683B (en) * | 2018-06-29 | 2022-03-18 | 深圳信息职业技术学院 | Method, apparatus and computer readable storage medium for host resource allocation |
CN109062683A (en) * | 2018-06-29 | 2018-12-21 | 深圳信息职业技术学院 | The method, apparatus and computer readable storage medium of host resource distribution |
CN109033468B (en) * | 2018-08-31 | 2022-09-16 | 创新先进技术有限公司 | Resource change processing method and device |
CN109033468A (en) * | 2018-08-31 | 2018-12-18 | 阿里巴巴集团控股有限公司 | The processing method and processing device of resource change |
CN109871336A (en) * | 2019-01-14 | 2019-06-11 | 珠海金山网络游戏科技有限公司 | A kind of dynamic buffering method of adjustment and system |
CN109871336B (en) * | 2019-01-14 | 2021-02-02 | 珠海金山网络游戏科技有限公司 | Dynamic cache adjusting method and system |
CN110187975B (en) * | 2019-06-04 | 2020-08-18 | 成都申威科技有限责任公司 | Multi-core processor resource allocation calculation method, storage medium and terminal equipment |
CN110187975A (en) * | 2019-06-04 | 2019-08-30 | 成都申威科技有限责任公司 | A kind of processor node distribution calculation method, storage medium and terminal device based on LBM |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104407925A (en) | Dynamic resource distribution method | |
US9069610B2 (en) | Compute cluster with balanced resources | |
US8392928B1 (en) | Automated workload placement recommendations for a data center | |
US8434088B2 (en) | Optimized capacity planning | |
KR101923706B1 (en) | Stochastic throttling | |
JP5332065B2 (en) | Cluster configuration management method, management apparatus, and program | |
US9374314B2 (en) | QoS aware balancing in data centers | |
JP5121936B2 (en) | RESOURCE ALLOCATION DEVICE, RESOURCE ALLOCATION PROGRAM, RECORDING MEDIUM, AND RESOURCE ALLOCATION METHOD | |
KR20130011491A (en) | Apparatus or task assignment, method for task assignment and a computer-readable storage medium | |
KR101471749B1 (en) | Virtual machine allcoation of cloud service for fuzzy logic driven virtual machine resource evaluation apparatus and method | |
US20170339069A1 (en) | Allocating Cloud Computing Resources In A Cloud Computing Environment | |
US20220121467A1 (en) | A method and a system for managing the computing resources of a cloud computing platform | |
CN110636388A (en) | Service request distribution method, system, electronic equipment and storage medium | |
CN111813523A (en) | Duration pre-estimation model generation method, system resource scheduling method, device, electronic equipment and storage medium | |
WO2016041446A1 (en) | Resource allocation method, apparatus and device | |
KR101630125B1 (en) | Method for resource provisioning in cloud computing resource management system | |
KR101695013B1 (en) | Method for allocating and managing of adaptive resource | |
CN107203256B (en) | Energy-saving distribution method and device under network function virtualization scene | |
CN113378498B (en) | Task allocation method and device | |
JP2005309868A (en) | Processing allocation management apparatus, control method for the same, and program | |
KR20150070930A (en) | Resource allocation system and method for migration considering optimal cost | |
JP2017091001A (en) | Virtual instance arrangement position determination device, virtual instance arrangement position determination method, and virtual instance arrangement position determination program | |
CN115774618A (en) | Cloud server iaas layer dynamic resource allocation method and device | |
CN111902804B (en) | System and method for managing resources of a storage device and quantifying I/O request costs | |
KR101584770B1 (en) | Resource allocation system and method for live migration |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20150311 |
|
RJ01 | Rejection of invention patent application after publication |