CN104407925A - Dynamic resource distribution method - Google Patents

Dynamic resource distribution method Download PDF

Info

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
Application number
CN201410758791.4A
Other languages
Chinese (zh)
Inventor
胡林
赵康
王敏讷
李金岭
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
China Telecom Digital Intelligence Technology Co Ltd
Original Assignee
China Telecom Group System Integration Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by China Telecom Group System Integration Co Ltd filed Critical China Telecom Group System Integration Co Ltd
Priority to CN201410758791.4A priority Critical patent/CN104407925A/en
Publication of CN104407925A publication Critical patent/CN104407925A/en
Pending legal-status Critical Current

Links

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

Dynamic resource allocation method
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)
<math> <mrow> <msub> <mi>b</mi> <mi>k</mi> </msub> <mo>=</mo> <mfrac> <mi>&alpha;</mi> <mrow> <mn>1</mn> <mo>-</mo> <mi>a</mi> </mrow> </mfrac> <mrow> <mo>(</mo> <msub> <mi>S</mi> <mi>k</mi> </msub> <mrow> <mo>(</mo> <mn>1</mn> <mo>)</mo> </mrow> <mo>-</mo> <msub> <mi>S</mi> <mi>k</mi> </msub> <mrow> <mo>(</mo> <mn>2</mn> <mo>)</mo> </mrow> <mo>)</mo> </mrow> </mrow> </math>
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)
<math> <mrow> <msub> <mi>b</mi> <mi>k</mi> </msub> <mo>=</mo> <mfrac> <mi>&alpha;</mi> <mrow> <mn>1</mn> <mo>-</mo> <mi>a</mi> </mrow> </mfrac> <mrow> <mo>(</mo> <msub> <mi>S</mi> <mi>k</mi> </msub> <mrow> <mo>(</mo> <mn>1</mn> <mo>)</mo> </mrow> <mo>-</mo> <msub> <mi>S</mi> <mi>k</mi> </msub> <mrow> <mo>(</mo> <mn>2</mn> <mo>)</mo> </mrow> <mo>)</mo> </mrow> </mrow> </math>
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)
<math> <mrow> <msub> <mi>b</mi> <mi>k</mi> </msub> <mo>=</mo> <mfrac> <mi>&alpha;</mi> <mrow> <mn>1</mn> <mo>-</mo> <mi>a</mi> </mrow> </mfrac> <mrow> <mo>(</mo> <msub> <mi>S</mi> <mi>k</mi> </msub> <mrow> <mo>(</mo> <mn>1</mn> <mo>)</mo> </mrow> <mo>-</mo> <msub> <mi>S</mi> <mi>k</mi> </msub> <mrow> <mo>(</mo> <mn>2</mn> <mo>)</mo> </mrow> <mo>)</mo> </mrow> </mrow> </math>
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%.
CN201410758791.4A 2014-12-10 2014-12-10 Dynamic resource distribution method Pending CN104407925A (en)

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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Patent Citations (3)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
Title
张婧: "《面向云计算运营管理的资源预测模型》", 《中国优秀硕士学位论文全文数据库》 *
米海波,王怀民,尹刚,史殿习,周扬帆,袁霖: "《一种面向虚拟化数字中心资源按需重配置方法》", 《软件学报》 *

Cited By (20)

* Cited by examiner, † Cited by third party
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