This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2014-059136, filed on Mar. 20, 2014, the entire contents of which are incorporated herein by reference.
This invention relates to a technique for allocating a virtual machine.
A proportion of electricity charges to an operational cost of a data center is large. According to a certain survey, the proportion of electricity charges to the operational cost of the data center is approximately 32.4%, although a proportion of electricity charges to a production cost of a large manufacturer is approximately 3%. Therefore, a company that manages the data center makes various efforts to reduce electricity consumption in the data center.
For example, a certain document focuses on a fact that resources of a physical server in the data center are not effectively used and electricity consumption becomes high as a result. Specifically, it is proposed to reallocate, based on a usage rate of the resources of the physical server, the resources to be allocated to virtual machines in order to reduce resources which are not used and reduce electricity consumption in a whole system.
Patent Document 1: Japanese Laid-open Patent Publication No. 2010-61278
However, even though the technique described above is used, there's a case where the resources of the physical server are not effectively used and a reduction of electricity consumption is not enough.
An allocation control method relating to one aspect of this embodiment includes: determining, for each of plural virtual machines executed on a first information processing apparatus or a second information processing apparatus, whether the virtual machine is executing a first processing that is performed in response to a request from an external apparatus; first allocating, to the first information processing apparatus, first virtual machines, which are executing the first processing, among the plural virtual machines; and second allocating, to the second information processing apparatus, second virtual machines, which are not executing the first processing, among the plural virtual machines.
The object and advantages of the embodiment will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the embodiment, as claimed.
The application servers 30 to 32 are servers to execute the operating VMs. The allocation management apparatus 1 migrates an idle VM, which has been in the idle state for a predetermined time or longer in the application server 30, from the application server 30 to the server 5 for idle VMs.
Application servers that do not execute a VM (in the example of
The server 5 for idle VMs is a server to execute idle VMs. When a VM started to work in the server 5 for idle VMs (in other words, an operating VM is detected), the allocation management apparatus 1 migrates the VM from the server 5 for idle VMs to the application server 30. Because it is assumed that the server 5 for idle VMs does not execute the transaction, computing performance of the server 5 for idle VMs may be lower than that of the application servers 30 to 32.
The quality management apparatus 7 is a server that collects performance data from the application servers 30 to 32 and the server 5 for idle VMs. The performance data includes date and time, a VM name, CPU utilization, an amount of I/O (Input/Output) data, and data traffic in a network or the like.
The controller 100 controls execution of a processing by the allocation management apparatus 1. The state specification unit 101 uses data stored in the performance data storage unit 109 and data stored in the threshold storage unit 110 to perform a processing, and stores a result of the processing in the state log storage unit 105. The calculator 102 uses data stored in the state log storage unit 105 to perform a processing, and stores a result of the processing in the time-series data storage unit 106. Moreover, the calculator 102 uses data stored in the time-series data storage unit 106 to perform a processing, and stores a result of the processing in the first VM data storage unit 107. Moreover, the calculator 102 uses data stored in the first VM data storage unit 107 to perform a processing, and stores a result of the processing in the second VM data storage unit 111. The detector 103 uses data stored in the time-series data storage unit 106 and data stored in the second VM data storage unit 111 to perform a processing, and stores a result of the processing in the script storage unit 108. The script execution unit 104 executes a script stored in the script storage unit 108.
In this embodiment, a VM, which is invariably in an idle state and never performs the transaction, (hereinafter referred to a VM for detection) is deployed to the server 5 for idle VMs separately from VMs for providing the service. The VM for detection is a VM which is used when detecting an idle VM.
Next, by using
When it is determined that the predetermined time has not passed (step S1: No route), the processing returns to the processing of the step S1. On the other hand, when it is determined that the predetermined time has passed (step S1: Yes route), the controller 100 outputs a request for execution of a processing to the state specification unit 101.
In response to this, the state specification unit 101 executes a state specification processing (step S3). The state specification processing is explained by using
First, the state specification unit 101 reads out performance data of the VM for detection in an immediate predetermined time period (for example, 24 hours) from the performance data storage unit 109. The performance data of the VM for detection is, for example, performance data whose VM name is “IDLE01” in
The state specification unit 101 compares performance data of each VM executed in the system in the immediate predetermined time period with thresholds stored in the threshold storage unit 110 to calculate an idle time for each VM in the immediate predetermined time period (step S23).
By using
In this embodiment, for example, a state of a VM is regarded as the idle state at a time when performance data is less than the threshold for any of the items. Therefore, in the examples illustrated in
An idle time calculated at the step S23 is stored in a storage device such as a main memory or the like, for example, in a format illustrated in
Then, the state specification unit 101 detects a VM whose ratio of the idle time to the immediate predetermined time period is equal to or greater than a threshold (for example, 0.9) (step S25). Then, the processing returns to the calling-source processing. A VM whose ratio of the idle time is equal to or greater than, for example, 0.9 is determined to be in the idle state. This is because it is possible to prevent a temporary processing (for example, a virus scan) from influencing the determination of the state. Incidentally, a VM which is in the idle state may not be detected at the step S25.
The state specification unit 101 stores a result of the processing at the step S25 in the state log storage unit 105.
As described above, it is possible to determine whether or not a VM is in an idle state with high precision because performance data of the VM for detection, which does not execute the transaction, is used.
Returning to the explanation of
Firstly, the calculator 102 converts a state log stored in the state log storage unit 105 into time-series data, and stores the time-series data in the time-series data storage unit 106 (
Then the calculator 102 sets a natural number n as 1, which represents the number of days that a VM has been in the idle state (step S33).
The calculator 102 generates, for each day of time-series data stored in the time-series data storage unit 106, first VM data by counting the number of VMs in each state (step S35) and stores the first VM data in the first VM data storage unit 107.
Then, the calculator 102 identifies the maximum value among the estimated numbers of operating VMs from the first VM data generated at the step S35 (step S37), and stores the maximum value in the second VM data storage unit 111. The maximum number is “2” when the first VM data is, for example, data illustrated in
The calculator 102 determines whether n=nmax holds (step S39). nmax is a natural number set by an administrator or the like in advance. For example, nmax is “7”. When it is determined that n=nmax does not hold (step S39: No route), the calculator 102 increments n by “1” (step S41). Then, the processing returns to the processing of the step S35. On the other hand, when it is determined that n=nmax holds (step S39: Yes route), the processing returns to the calling-source processing.
By executing the processings described above, data as illustrated in
Here, an explanation of the calculation processing is added.
Therefore, the maximum number of operating VMs on the server 5 for idle VMs is 31 in the examples illustrated in
Returning to the explanation of
Firstly, the detector 103 calculates Vnum that is the number of VMs that the server 5 for idle VMs can execute (
The detector 103 searches for n that satisfies (the maximum number of VMs≦Vnum) in the second VM data storage unit 111 (step S53).
The detector 103 determines whether n that satisfies (the maximum number of VMs Vnum) has been detected at the step S53 (step S55). When it is determined that n has not been detected (step S55: No route), the processing returns to the calling-source processing because VMs are not migrated.
On the other hand, when it is determined that n has been detected (step S55: Yes route), the detector 103 detects, from the time-series data storage unit 106, VMs executed on one of the application servers 30 to 32 among VMs which have been in the idle state for n (here, the detected n) days or more (step S57).
The detector 103 detects, from the time-series data storage unit 106, VMs executed on the server 5 for idle VMs among operating VMs (step S59). Then, the processing ends.
By performing processings described above, it is possible to prevent performance of the transaction executed by operating VMs on the server 5 for idle VMs from degrading severely and to migrate idle VMs to the server 5 for idle VMs.
For example, the detector 103 may display a value of the detected n on a display device or the like of the allocation management apparatus 1. Thus, an operator of the allocation management apparatus 1 can check the value of n and select a physical server whose memory capacity is proper as the server 5 for idle VMs.
Returning to the explanation of
On the other hand, when it is determined that the VMs have been detected at the step S57 or step S59 (step S9: Yes route), the detector 103 generates a script to migrate the detected VMs (step S11), and stores the script in the script storage unit 108. Then, the processing returns to the processing of the step S1.
Assume that an application server that is a destination of a migration is, for example, an application server whose available memory amount is the largest. For example, as illustrated in
Then, assume that available memory capacity of each application server comes to a state illustrated in
When the processing returns to the processing of the step S1, the controller 100 deletes the time-series data stored in the time-series data storage unit 106, the first VM data stored in the first VM data storage unit 107, the script stored in the script storage unit 108, the thresholds stored in the threshold storage unit 110, and the second VM data stored in the second VM data storage unit 111.
It is possible to reduce the number of operating physical servers even when collecting up VMs simply based on CPU utilization or the like. However, there's a case where memory overcommit occurs and performance of the transaction degrades due to memory consumption by idle VMs. Namely, a state in which an available memory amount is not enough although CPU utilization is low occurs in an application server. However, in this embodiment, since a script for allocating an idle VM and an operating VM on different servers is generated, it is possible to allocate so as to suppress performance degradation of the transaction.
Next, by using
When it is determined that the script does not exist (step S63: No route), the processing returns to the processing of the step S61. On the other hand, when it is determined that the script exists (step S63: Yes route), the script execution unit 104 executes the script stored in the script storage unit 108 (step S65). Then, the processing returns to the processing of the step S61.
An operator of the allocation management apparatus 1 causes a display device (for example, monitors or the like) to display, for example, a window illustrated in
As described above, by migrating VMs that do not execute the transaction to the server 5 for idle VMs, it is possible to suppress performance degradation of the transaction and reduce the number of working physical servers. In other words, it is possible to use resources of physical servers effectively and reduce electricity consumption.
Moreover, because the number of idle VMs executed by an application server becomes less and memory usage of the application server becomes less, it is possible to prevent memory overcommit from occurring in the application server. Moreover, even when operating VMs are collected up to the application server, the memory overcommit hardly occurs.
Incidentally, there's a possibility that the memory overcommit occurs in the server 5 for idle VMs. However, because idle VMs do not execute the transaction and operating VMs are migrated to an application server at a time when the operating VMs are detected, the transaction is hardly affected.
Moreover, once idle VMs are stopped, a reboot is required before the VMs execute the transaction. Therefore, it takes a while to start execution of the transaction. For example, consider that 450 VMs exist and it takes 1 minute to stop and reboot one VM. In this case, a loss of a time (whose length is 450 minutes=7 hours and 30 minutes) occurs when each VM reboots once. However, it is possible to restart the transaction quickly and users of the service are scarcely affected because any idle VMs are not stopped in this embodiment.
Although the embodiment of this invention was explained above, this invention is not limited to those. For example, the functional block configuration of the allocation management apparatus 1 do not always correspond to a program module configuration.
Moreover, the respective formats of the aforementioned tables are mere examples, and may be changed. Furthermore, as for the processing flow, as long as the processing results do not change, the turns of the steps may be exchanged or the steps may be executed in parallel.
Incidentally, although the number of the server 5 for idle VMs is 1 in the aforementioned example, the number of the server 5 for idle VMs may be more than 1.
In this appendix, matters relating to this embodiment are explained.
(1) A Memory Amount Allocated to VMs.
When the number of VMs operating on a physical server gradually increases, performance dramatically degrades in a specified timing. This is explained by using a graph of
(2) CPU Utilization in a Data Center.
It is pointed out that there are many idle VMs in a data center and resources of physical servers are not used effectively. This is explained by using a graph of
In addition, the aforementioned allocation management apparatus 1, application servers 30 to 32, server 5 for idle VMs, and quality management apparatus 7 are computer devices as illustrated in
The aforementioned embodiment is summarized as follows:
An allocation control method relating to a first aspect of this embodiment includes: (A) determining, for each of plural virtual machines executed on a first information processing apparatus or a second information processing apparatus, whether the virtual machine is executing a first processing that is performed in response to a request from an external apparatus; (B) first allocating, to the first information processing apparatus, first virtual machines, which are executing the first processing, among the plural virtual machines; and (C) second allocating, to the second information processing apparatus, second virtual machines, which are not executing the first processing, among the plural virtual machines.
Thus, because the first processing is not affected even when memory overcommit and the like occur in the second information processing apparatus, virtual machines can be gathered in the second information processing apparatus. Therefore, it is possible to reduce the number of information processing apparatuses used for execution of virtual machines and use resources of information processing apparatuses effectively. Moreover, it is possible to suppress performance degradation of the first processing because memory overcommit, which occurs due to virtual machines which do not execute the first processing, can be prevented from occurring in the first information processing apparatus.
Moreover, the determining may include: (a1) obtaining information on a state of a third virtual machine that is allocated to the second information processing apparatus in advance, is not included in the plural virtual machines and does not execute the first processing; and (a2) comparing, for each of the plural virtual machines, information on a state of the virtual machine with the obtained information on the state of the third virtual machine to determine whether the virtual machine is executing the first processing. As described above, because the information on the state of the virtual machine that do not execute the first processing is used, it can be determined, with high accuracy, whether the virtual machine is executing the first processing or not.
Moreover, the second allocating may include: (c1) detecting fourth virtual machines that have not executed the first processing for a first time period or longer in the first information processing apparatus; and (c2) third allocating the fourth virtual machines to the second information processing apparatus. By performing a processing described above, it is possible to prevent memory of the first information processing apparatus from being occupied by virtual machines which do not execute the first processing.
Moreover, (b1, c3) the first allocating and the second allocating may be performed periodically. Thus, it is possible to prevent a processing load from growing large.
Moreover, the allocation control method may further include: (D) first calculating a first number of virtual machines that the second information processing apparatus can execute by using information on memory capacity of the second information processing apparatus and information on an amount of memory allocated to one virtual machine; and (E) second calculating, by using an operational history, the first time period under a condition that a second number of virtual machines does not exceed the first number of virtual machines, wherein the second number of virtual machines is a number of virtual machines that starts to execute the first processing in the second information processing apparatus during a time period from a last execution of the first allocating to a next execution of the first allocating. The shorter the first time period is, the greater the second number of the virtual machines is. Then, performance of the first processing executed in the second information processing apparatus degrades. Therefore, by performing a processing described above, it is possible to suppress performance degradation of the first processing executed in the second information processing apparatus.
Moreover, processing performance of the second information processing apparatus may be lower than processing performance of the first information processing apparatus. It does not matter whether the processing performance of the second information apparatus is high or not, because the first processing is not executed in the second information processing apparatus. Therefore, it is possible to effectively use an information processing apparatus whose processing performance is relatively low.
Moreover, a total amount of memory allocated to the second virtual machines is larger than memory capacity of the second information processing apparatus. Even when memory overcommit occurs, it has no influence on the first processing.
Moreover, the second calculating includes: (e1) third calculating, for each term of plural successive terms, a third number of virtual machines that started to execute the first processing in the term and had not executed the first processing for the first time period or longer before the term; (e2) first identifying a maximum number of virtual machines from among the calculated third numbers of virtual machines; (e3) executing the third calculating and the first identifying plural times while changing the first time period; second identifying, from among the identified maximum numbers, a first maximum number that is equal to or less than the first number of virtual machines; and (e4) third identifying the first time period that corresponds to the identified first maximum number. By performing a processing described above, it is possible to identify the first time period properly.
An allocation control apparatus relating to a second aspect of this embodiment includes circuitry or a processor programmed to determine, for each of plural virtual machines executed on a first information processing apparatus or a second information processing apparatus, whether the virtual machine is executing a first processing that is performed in response to a request from an external apparatus, to allocate, to the first information processing apparatus, first virtual machines, which are executing the first processing, among the plural virtual machines, and to allocate, to the second information processing apparatus, second virtual machines, which are not executing the first processing, among the plural virtual machines.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiments of the present inventions have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2014-059136 | Mar 2014 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
7203944 | van Rietschote | Apr 2007 | B1 |
8627315 | Li | Jan 2014 | B2 |
8813240 | Northup | Aug 2014 | B1 |
20040107273 | Biran et al. | Jun 2004 | A1 |
20080163239 | Sugumar | Jul 2008 | A1 |
20080295096 | Beaty | Nov 2008 | A1 |
20090138887 | Uehara et al. | May 2009 | A1 |
20110099403 | Miyata et al. | Apr 2011 | A1 |
20120331147 | Dutta | Dec 2012 | A1 |
20140032761 | Beveridge | Jan 2014 | A1 |
Number | Date | Country |
---|---|---|
2006-508445 | Mar 2006 | JP |
2009-151745 | Jul 2009 | JP |
2010-61278 | Mar 2010 | JP |
2011-90594 | May 2011 | JP |
2013-242797 | Dec 2013 | JP |
2012053115 | Apr 2012 | WO |
Entry |
---|
Office Action of Japanese Patent Application No. 2014-059136 dated Oct. 31, 2017 (with machine generated English translation). |
Number | Date | Country | |
---|---|---|---|
20150269002 A1 | Sep 2015 | US |