Many computing processes are virtualized to enable efficient partitioning of remote host resources among multiple users. The resources of a host are partitioned into respective system and/or process-based virtual machines. Some virtual machines may be statically provisioned to service an organization (e.g., a business, a corporation, a government entity, a school, etc.) while other virtual machines may be dynamically provisioned to service individual users, Oftentimes, virtual machines have to be migrated between different hosts. For example, a virtual machine may be migrated when a host is operating close to capacity, when a host experiences an operational issue, or when a host needs to be deactivated for servicing. In these examples, operators of the migrated virtual machines attempt to reduce a time the virtual machines are offline and/or unavailable to users.
Virtual machines are instances of applications operating on a host in a virtual environment and which are only accessible to designated users. Many virtual machines are implemented on hosts (e.g., servers, blade servers, server racks, processors, computers, microprocessors, etc.) that are remote and/or centrally located in relation to users. The remoteness of virtual machines enables clients and/or customers to lease and/or purchase processing capacity and/or bandwidth allocated among at least one host instead of purchasing and/or leasing physical devices. In these instances, a virtual machine is instantiated to operate for the client and/or customers using allocated partitions of one or more hosts. These virtual machines also enable clients and/or customers to access data and/or use proprietary processes from any location and/or from any device (e.g., cloud computing).
Data center operators frequently migrate virtual machines between hosts for various reasons including, for example, to alleviate performance issues, to improve capacity allocations, and/or to support maintenance tasks. Some known methods of migrating virtual machines include procedures to reduce a downtime of the virtual machines by increasing a speed at which the virtual machines are migrated. Other known methods include using rule sets specified by clients and/or customers that describe which servers and/or physical locations can host a virtual machine. In yet other known methods, virtual machines are migrated based on manual selections by data center operators.
The migration of virtual machines can incur security risks. For example, a virtual machine migration can be disturbed by malicious competition for networking and/or processing resources of components (e.g., switches, servers, processors, etc.) used to migrate the virtual machines. In other examples, virtual machine migration provides access to a virtual machine state which includes, for example, sensitive application data (e.g., user identification, passwords), application states, an operating system kernel memory, etc. These potential security risks may deter some customers and/or clients from wanting their virtual machines migrated.
Additionally, different virtual machines can have different costs to migrate. For example, some virtual machines may utilize more memory, thereby requiring a relatively longer migration time that consumes relatively more bandwidth. Some virtual machines may have frequently updated memory, which makes completing the migration process more difficult because memory states have to be transmitted more frequently. In yet other examples, some virtual machines may require specialized provisioning to accommodate a unique application, thereby increasing a time to migrate and provision a virtual machine on a new host. In many known methods, data center operators do not quantify these costs when determining which virtual machines to migrate.
Further, customers and/or clients who own and/or lease virtual machines may want to limit how frequently the virtual machines are migrated to reduce an impact on business services. For example, a client who leases a virtual machine may not want virtual machines operating a customer-facing storefront application to be migrated more than three times per week to reduce an amount of time the storefront is unavailable to customers. Additionally, customers and/or clients may want to specify during what times and/or on which days virtual machines may be migrated. While some known methods consider customer and/or client preferences, these known methods only consider the affects of migrating virtual machines associated with one client and/or customer.
Example systems, methods, apparatus, and articles of manufacture disclosed herein address at least some these problems by determining an impact of migrating differing numbers of virtual machines between hosts based on a combination of virtual machine performance, host capacity, known security preferences, quantifications of migration cost, and/or estimations of migration risk. The example systems, methods, apparatus, and articles of manufacture disclosed herein enable customers and/or clients of virtual machines to specify security criteria, performance thresholds, and/or frequency thresholds that a data center operator uses to determine which virtual machines should be migrated. This enables customers and/or clients to have confidence that any migrations of their virtual machines should not adversely affect hosted operators and/or services.
The example systems, methods, apparatus, and articles of manufacture disclosed herein also provide direction for data center operators as to which virtual machines can be migrated based on capacity conditions of hosts and/or measured performance of the virtual machines. The example data center operators use the example systems, methods, apparatus, and articles of manufacture disclosed herein to determine how many migrations of virtual machines are needed to achieve certain capacity savings among hosts and/or to overcome performance issues among at least some of the hosted virtual machines. For example, instead of determining that performance of one virtual machine may be improved with one migration, the example systems, methods, apparatus, and articles of manufacture disclosed herein coordinate migrations of multiple virtual machines to improve capacity among hosts while maintaining and/or improving performance among the virtual machines.
Additionally, the example systems, methods, apparatus, and articles of manufacture disclosed herein migrate virtual machines operating similar applications to hosts that have hardware, firmware, software and/or other resources that are specifically configured for the applications, thereby improving performance of the virtual machines while improving efficiency among the hosts. In this manner, capacity on hosts can be improved by consolidating virtual machines on hosts with similar applications, services, and/or operating systems so that each host does not have to be configured to operate different types of applications, services, and/or operating systems. Further, consolidating similar types of virtual machines helps improve logistics and/or operations of data centers.
The example systems, methods, apparatus, and articles of manufacture disclosed herein also help data centers maintain satisfaction among clients and/or customers by only migrating virtual machines based on conditions specified by the clients and/or customers. For example, in many known data centers, virtual machines are migrated based on capacity constraints of hosts resulting from increases in traffic from customers and/or clients. However, migrating a frequently used virtual machine may cause a service disruption during a time when the virtual machine is used most often and may expose the virtual machine to security risks. The example systems, methods, apparatus, and articles of manufacture disclosed herein enable these customers and/or clients to specify that a slight performance reduction is acceptable instead of temporarily removing a virtual machine from service during migration and exposing the virtual machine to possible security threats.
While the example systems, methods, apparatus, and articles of manufacture disclosed herein are described in conjunction with migrating virtual machines among hosts including, for example servers, the example systems, methods, apparatus and articles of manufacture disclosed herein may migrate virtual machines among processors, network switches, controllers, memories, databases, computers, etc. Further, while the example systems, methods, apparatus and articles of manufacture disclosed herein are described in conjunction with migrating virtual machines provisioned for an organization, the example systems, methods, apparatus and articles of manufacture disclosed herein may be implemented for network providers, service providers, cloud computing operators, government agencies, individual users, etc.
In the illustrated example, the data center 106 includes hosts 108, 110, and 112. The example hosts 108-112 include any type of server, blade server, processor, computer, memory, database, controller, and/or network switch that can operate virtual machines 114-124. In some examples, the data center 106 is located in a single physical location. Alternatively, the data center 106 may represent different physical locations where the hosts 108-112 are geographically separate from each other. In other examples, the data center 106 can include additional hosts, fewer hosts, additional virtual machines, and/or fewer virtual machines.
The example data center 106 of
The example client administrator 128 includes any customer and/or client who requests from the data center 106 one or more of the virtual machines 114-124 to host, for example, an application, data, service, etc. The example client administrator 128 may be associated with an organization that includes, for example, the virtual machine users 102. For example, the client administrator 128 may include an Internet Technology (IT) department of a company and the virtual machine users 102 are employees and/or contractors of the company. In other examples, the client administrator 128 may include a service provider and the virtual machine users 102 subscribe to access a virtual machine. For example, the client administrator 128 leases the virtual machine 114. In this example, the virtual machine users 102 subscribe to the client administrator 128 to access applications and/or data hosted by the virtual machine 114. In other examples, the client administrator 128 may include a company with an online storefront hosted by the virtual machine 114. In these other examples, the virtual machine users 102 access a webpage hosted by the virtual machine 114 to purchase services and/or goods provided by the client administrator 128.
The client administrator 128 provides requirements for hosting a virtual machine including an amount of bandwidth, Internet Protocol (IP) addresses to be associated with a virtual machine, geographic preferences for the virtual machine, an operating system type supported by the virtual machine, applications to be operated by the virtual machine, memory to be available for the virtual machine, data storage capacity, etc. Additionally, the example client administrator 128 can specify minimum performance thresholds for a virtual machine, a security risk ranking to be associated with a virtual machine, and/or an allowed migration frequency for a virtual machine. Further, the example client administrator 128 may provide logistic information including billing information.
To process requests from the example client administrator 128 and/or to manage the example virtual machines 114-124 within the data center 106, the example system 100 includes a virtual machine manager 130. The example virtual machine manager 130 provisions the hosts 108-112 based on information provided by the example client administrator 128. The virtual machine manager 130 provisions the hosts 108-112 by allocating processing and/or memory capacity from among the hosts 108-112 for the virtual machines 114-124 and/or configuring hardware, firmware, software, and/or any other resources on the hosts 108-112 to operate the virtual machines 114-124. The example virtual machine manager 130 also updates routing tables within the data center 106 so communications from, for example, the workstations 104 are routed to the appropriate virtual machines 114-124.
In the illustrated example, the virtual machine manager 130 is shown external to the data center 106, in this example, the example virtual machine manager 130 may be operated by an entity separate from the data center 106. In these examples, the virtual machine manager 130 may also migrate virtual machines among hosts included in different data centers. Alternatively, the virtual machine manager 130 and the data center 106 may be operated and/or managed by the same entity. In these alternative examples, the virtual machine manager 130 may be included within the data center 106.
The example virtual machine manager 130 of
The example virtual machine manager 130 of the illustrated example determines to migrate the virtual machines 114-124 if capacity approaches and/or exceeds capacity limits and/or performance approaches and/or exceeds the thresholds. To determine which of the virtual machines 114-124 to migrate, the example virtual machine manager 130 determines an impact on capacity and/or performance as a result of moving each of the virtual machines 114-124. For example, the virtual machine manager 130 initially determines an impact on capacity of the hosts 108-112 based on migrating the virtual machine 114. The example virtual machine manager 130 also determines an impact on performance by migrating the virtual machine 114 to either of the hosts 110 and 112. In some examples, the virtual machine 114 may be migrated only if the impact of migrating the virtual machine is less than an impact threshold.
Additionally, the example virtual machine manager 130 determines security risks for migrating each of the virtual machines 114-124. The security risks may be specified by, for example, the client administrator 128. In the example of
In addition to determining security risks, the example virtual machine manager 130 of
Prior to migrating the virtual machines 114-124, the example virtual machine manager 130 determines if any of the identified virtual machines to be migrated will exceed a specified (e.g., allowed) migration frequency, For example, the virtual machine manager 130 may determine that the virtual machine 114 with a migration frequency of two moves per 24 hour time period has already been migrated twice in the past day. In this example, the virtual machine manager 130 determines that the virtual machine 114 is currently not available to migrate and selects another of the virtual machines 116-124 to migrate, Alternatively, the example virtual machine manager 130 may initially filter out which of the virtual machines 1140-124 to migrate based on current migration frequency before determining which virtual machines should be migrated to resolve capacity/performance issues.
The example virtual machine manager 130 of
The example virtual machine manager 130 of the illustrated example migrates the virtual machines 114-124 after identifying which virtual machines should not be migrated based on security risks, migration frequencies, and/or reliability ratings. In some instances, the example virtual machine manager 130 may determine that the virtual machine 114 can be migrated to the host 110. In these instances, the example virtual machine manager 130 then iteratively determines any additional capacity savings and/or performance improvements from migrating any of the other virtual machines 116-124 concurrently and/or subsequently to migrating the virtual machine 114. Thus, in some examples, the virtual machine manager 130 determines a total capacity savings and total performance improvement based on concurrently migrating a group and/or set of virtual machines.
The example client interface 202 of
The example client interface 202 of the illustrated example enables, for example, the client administrator 128 to access associated information within the virtual machine database 204. For example, the client administrator 128 uses the client interface 202 to modify a security risk, a migration frequency threshold, a performance threshold, and/or a reliability rating of a virtual machine. In other instances, the client administrator 128 specifies, via the client interface 202, a time of day and/or a day of the week that a virtual machine is allowed to be migrated.
To determine which of the virtual machines 114-124 to migrate, the example virtual machine manager 130 of
The example performance monitor 208 of
The example capacity monitor 210 measures an amount of capacity utilized by each of the hosts 108-112. The example capacity monitor 210 determines capacity based on, for example, an amount of resources of the hosts 108-112 utilized by each of the virtual machines 114-124. The example capacity monitor 210 transmits capacity data to the migration processor 206 for analysis.
The example migration processor 206 uses the capacity and/or performance data to determine any performance and/or capacity issues. For example, the migration processor 206 determines that the virtual machine 114 is operating at a performance level (e.g., a QoS) below a threshold specified by the client administrator 128. In other examples, the migration processor 206 may determine which of the hosts 108-112 are operating at capacity and/or beyond capacity In both of these examples, the migration processor 206 determines which of the virtual machines 114-124 can be migrated to reduce the performance and/or capacity issues.
The example migration processor 206 of the illustrated example also uses the capacity and/or performance data from the respective monitors 208 and 210 to determine performance and/or capacity impacts of migrating the virtual machines 114-124. For example, the migration processor 206 may use the data to determine how total capacity of the data center 106 can be reduced by migrating some of the virtual machines 114-124 to different hosts (e.g., migrating the virtual machine 118 to the host 112 to enable the virtual machine manager 130 to deactivate the host 110, thereby reducing energy consumption). In other examples, the migration processor 206 may use the data to determine how an average performance of the virtual machines 114-124 can be improved by migrating some of the virtual machines 114-124.
In some examples, the migration processor 206 of
Ahost110=max_shareshost110−peak_shares_usedhost110 (1)
The example migration processor 206 determines a capacity savings Sv2 based on migrating the virtual machine 114 to the host 110 using an example equation (2). The capacity savings is related to moving the workload v from the virtual machine 114 to the host 110.
Sv2=Ahost108−Ahost110 (2)
The example migration processor 206 also calculates capacity savings and/or decreases in capacity based on migrating the other virtual machines 116-124 to determine which of the virtual machines 114-124 should be migrated to best utilize capacity among the hosts 108-112. In some instances, the example migration processor 206 predicts future capacity and/or performance of the virtual machines 114-124 based on historical trace data of previous virtual machine performance. The historical trace data is stored in, for example, the virtual machine database 204.
The example migration processor 206 of
To determine a migration frequency threshold, for the virtual machines 114-124, the example migration processor 206 accesses a migration permission manager 214. The example migration permission manager 214 uses identifiers of the virtual machines 114-124 to retrieve a corresponding migration frequency threshold and/or a current migration frequency for each of the virtual machines 14-124 The migration permission manager 214 then transmits tie threshold and/or current migration frequency to the migration processor 206. The example migration permission manager 214 also tracks which of the virtual machines 114-124 are migrated and updates the corresponding current migration frequency to reflect the most recent migration. Further, the migration permission manager 214 updates the current migration frequency for each of the virtual machines 114-124 for each time period.
To determine a reliability index for the virtual machines 114-124, the example migration processor 206
The example migration complexity manager 216 of the illustrated example also creates and/or modifies the reliability ratings each time the corresponding virtual machines 114-124 are migrated. For example, the migration complexity manager 216 may monitor an amount of time to migrate and provision the virtual machine 114 on the host 110 and update a reliability rating to reflect the monitored time. The example migration complexity manager 216 may also create a reliability rating for each of the virtual machines 114-124 for different times of a day or different days of a week. In this manner, the example migration processor 206 may use this dayitime information to schedule virtual machine migrations when reliability ratings are relatively high (e.g., a low expected difficulty to migrate the virtual machines).
In other examples, the migration complexity manager 216 may modify the reliability ratings stored in the virtual machine database 204 based on a number and/or amount of resources needed to achieve a virtual machine migration. For example, larger memory sizes and/or more supervision to migrate a virtual machine may cause the migration complexity manager 216 to calculate a lower reliability rating. In other examples, the migration complexity manager 216 may interface with the performance monitor 208 to calculate a reliability rating based on an initial QoS of a newly migrated virtual machine.
After receiving security ranks, reliability ratings, and/or migration frequency information, the example migration processor 206 selects which virtual machines 114-124 to migrate. The example migration processor 206 selects the virtual machines to migrate by determining if any of the information restricts any of the virtual machines from being migrated. For example, virtual machines with a relatively high security rank, a relatively low reliability rating, and/or a frequency migration that exceeds an allowed migration frequency may be removed from planned migration by the migration processor 206. The migration processor 206 then migrates the remaining virtual machines using the capacity and/or performance impact calculations for the corresponding virtual machines.
Alternatively, the example migration processor 206 may calculate a migration score for each of the virtual machines 114-124 identified to be migrated. The migration score corresponds to an average weighted average, sum, etc. of a security rank, a reliability rating, a migration frequency, a performance impact, and/or a capacity savings. For example, the migration processor 206 may calculate a migration score for the virtual machine 114 moving to the host 110 based on a high reliability (e.g., a value of 3), a low security rank (e.g., a value of 3), a low number of current migrations (e.g., a value of 2), a moderate performance improvement (e.g., a value of 2), and a low capacity savings (e.g., a value of 1). In this example, the migration score is a sum of the values (e.g., a value of 9). The migration processor 206 then determines if the virtual machine 114 can be migrated if the calculated value is greater than a predetermined threshold value of ‘5.’ In this instance, the migration processor 206 determines that the virtual machine 114 can be migrated to the host 110.
In these alternative examples, the migration processor 206 of
After determining which of the virtual machines 114-124 to migrate and which of the hosts 108-112 will receive the virtual machines 114-124, the example migration processor 206 of
In this example, the host interface 218 of
In examples where the example host interface 218 of
While an example manner of implementing the example virtual migration manager 130 has been illustrated in
The example table 302 shows that the host 108 has a total capacity of 10 GHz and the hosts 110 and 112 each have a total capacity of 6 GHz. The example table 302 also shows that the host 108 includes the virtual machines 114 and 116, the host 110 includes the virtual machine 118, and the host includes the virtual machine 120. The example table 302 also indicates that the host 108 has 5 GHz of capacity (e.g., resources) available, the host 110 has no capacity available, and the host 112 has 1 GHz of capacity available. In other examples, the table 302 may include information specifying an amount of memory used and/or available on the hosts 108-112 or, alternatively, an amount of processor space used and/or available on the hosts 108-112.
The example migration processor 206 of
An example table 304 shows a calculated performance by the example migration processor 206 of the effects of migrating the virtual machine 118 (e.g. VM B1) to the host 108. The ‘1’ value in the table 304 indicates that the host 108 would need 1 GHz of additional capacity to accommodate the migration of the virtual machine 118 (e.g., the total capacity of the virtual machines 114-118 would be 11 GHz). The ‘1’ value also indicates that the virtual machine 118 would suffer adverse performance from a lack of capacity at the host 108. The ‘X’ values in the table 304 indicate that the migration processor 206 has not computed the effects of migrating the virtual machines 114-118 to the hosts 108-112.
The example table 304 of
In other examples, the migration processor 206 utilizes other methods for determining performance a and/or capacity impacts. For example, the migration processor 206 may calculate performance using QoS violations and/or weighted performance based on an importance of workloads, In other examples, the migration processor 206 determines capacity impacts as a function of virtual machine performance.
In the example table 402 of
The example risk impact indicates under which conditions it is acceptable for the migration processor 206 to migrate a virtual machine. In this example, the risk impact of 25% indicates that the virtual machine 116 can be migrated if the effective cost and/or quantity of resources used to host the virtual machine 116 is reduced by 25%. In other words, the virtual machine 116 can be migrated if capacity is improved by 25%. or performance is improved by 25%.
The example migration processor 206 uses the security rankings in the example table 402 to determine that the virtual machines 118 and 120 cannot be migrated because of the ‘High’ security rank. The migration processor 206 then determines whether to migrate the virtual machines 114 and 116 based on the ‘Medium’ and ‘Low’ security rankings. In some examples, the migration processor 206 may use the table 402 to determine initially which virtual machines cannot be migrated prior to determining performance and/or capacity impacts, as described in
The example migration processor 206 uses the example table 502 to determine which of the virtual machines 114-120 may be migrated. Using the information in the table 402 of
The example migration processor 206 uses the example table 602 to determine which of the virtual machines 114-120 can be migrated. Based on the determinations in conjunction with
An example table 704 shows a revised performance and capacity impact of the hosts 108-112 based on a planned migration of the virtual machines 108-112. The example migration processor 206 uses the performance and/or capacity impacts in conjunction with the information in the tables 402, 502, and 602 to determine which of the virtual machines 114-120 can be migrated to further improve performance and/or capacity. Thus, the example migration processor 206 can iteratively determine virtual machines to migrate based on the example methods described on conjunction with
In other instances, the migration processor 206 may determine the performance and/or capacity impacts shown in table 704 at some predetermined time after migrating the virtual machine 114. Alternatively, the example migration processor 206 determines which of the virtual machines 114-120 to migrate based on a detected performance and/or capacity issue. In this manner, the example migration processor 206 determines periodically if the virtual machines 114-120 should be migrated to compensate for different usages (e.g., peak usages) during different times of a day and/or different days of a week.
Flowcharts representative of example machine readable instructions for implementing the virtual machine manager 130 of
As mentioned above, the example machine readable instructions of
The example machine-readable instructions 800 of
If the migration processor 206 determines there are no opportunities to improve capacity and/or performance, the example monitors 208 and 210 continue to measure and record host capacity and/or virtual machine performance (block 802). If there are opportunities for better utilization and/or there is at least one capacity and/or performance issue, the example migration processor 206 calculates performance impacts of migrating each virtual machine (block 808). The example migration processor 206 also calculates host capacity changes of migrating each virtual machine (block 810). Based on the determined performance impacts and/or capacity changes, the example migration processor 206 determines which virtual machines should be migrated (block 812).
The example migration processor 206 next accesses the security manager 212 to determine if security rankings indicate that one or more of the virtual machines should not be migrated (block 814). For each virtual machine with a security ranking that prevents the virtual machine from being migrated, the example migration processor 206 removes the virtual machine from the group and/or set of virtual machines to be migrated (block 816). The example migration processor 206 then accesses the migration permission manager 214 to determine if migration frequencies indicates the respective virtual machines should not be migrated (block 818). If the migration frequency restricts a virtual machine from being migrated, the example migration processor 206 removes the virtual machine from migration consideration (block 816). The example migration processor 206 next accesses the migration complexity manager 216 to determine if reliability ratings indicates the respective virtual machines should not be migrated (block 820). If the reliability rating restricts a virtual machine from being migrated, the example migration processor 206 removes the virtual machine from migration consideration (block 816).
The example migration processor 206 then migrates the remaining virtual machines to the corresponding hosts (block 822). In some examples, the migration processor 206 may determine which virtual machines should be migrated after determining which virtual machines cannot be migrated. In yet other examples, the migration processor 206 uses an average and/or weighted score of security rank, migration frequency, reliability rating, performance improvement, and/or capacity savings to determine which virtual machines to migrate. After migrating the virtual machines, the example monitors 208 and 210 return to monitoring host capacity and/or virtual machine performance (block 802).
The example machine-readable instructions 900 of
If the migration processor 206 determines there are no opportunities to improve capacity and/or performance, the example monitors 208 and 210 continue to measure and record host capacity and/or virtual machine performance (block 902). If there are opportunities for better utilization and/or there is at least one capacity and/or performance issue, the example migration processor 206 calculates performance impacts of migrating each virtual machine (block 908). To determine which virtual machines to migrate, the example migration processor 206 via the managers 212 and 216 and/or the monitors 208 and 210 calculates an average and/or weighted score of security rank, migration frequency, reliability rating, performance improvement, and/or capacity savings (block 910).
The example migration processor 206 determines which virtual machines correspond to a calculated score that is above a threshold and/or identify the virtual machines with the greatest score to determine which virtual machines can be migrated (block 912). The example migration processor 206 also determines which virtual machines have a security ranking, migration frequency, and/or reliability rating that prevent the virtual machines from being migrated (block 912). For the virtual machines that cannot be migrated, the example migration processor 206 removes the virtual machines from among the virtual machines to be migrated (block 914). The example migration processor 206, via the host interface 218, then migrates the remaining virtual machines with scores above a predefined threshold (block 912). After migrating the virtual machines, the example monitors 208 and 210 return to monitoring host capacity and/or virtual machine performance (block 902).
The example machine-readable instructions 1000 of
The processor platform P100 of
The processor P105 executes coded instructions P110 and/or P112 present in main memory of the processor P105 (e.g., within a RAM P115 and/or a ROM P120) and/or stored in the tangible computer-readable storage medium P150. The processor P105 may be any type of processing unit, such as a processor core, a processor and/or a microcontroller. The processor P105 may execute, among other things, the example interactions and/or the example machine-accessible instructions 800, 900, and/or 1000 of
The processor P105 is in communication with the main memory (including a ROM P120 and/or the RAM P115) via a bus P125, The RAM P115 may be implemented by dynamic random access memory (DRAM), synchronous dynamic random access memory (SDRAM), and/or any other type of RAM device, and ROM may be implemented by flash memory and/or any other desired type of memory device. The tangible computer-readable memory P150 may be any type of tangible computer-readable medium such as, for example, compact disk (CD), a CD-ROM, a floppy disk, a hard drive, a digital versatile disk (DVD), and/or a memory associated with the processor P106. Access to the memory P115, the memory P120, and/or the tangible computer-medium P150 may be controlled by a memory controller. In some examples, the coded instructions P110 are part of an installation pack and the memory is a memory from which that installation pack can be downloaded (e.g., a server) or a portable medium such as a CD, DVD, or flash drive. In some examples, the coded instructions are part of installed software in the RAM P115, the ROM P120, and/or the computer-readable memory P150.
The processor platform P100 also includes an interface circuit P130. Any type of interface standard, such as an external memory interface, serial port, general-purpose input/output, etc. may implement the interface circuit P130. One or more input devices P135 and one or more output devices P140 are connected to the interface circuit P130.
Although the above described example systems, methods, apparatus and articles of manufacture including, among other components, software and/or firmware executed on hardware, it should be noted that these examples are merely illustrative and should not be considered as limiting. For example, it is contemplated that any or all of the hardware, software, and firmware components could be embodied exclusively in hardware, exclusively in software, or in any combination of hardware and software. Accordingly, while the above described example systems, methods, apparatus, and articles of manufacture, the examples provided herein are not the only way to implement such systems, methods, apparatus, and articles of manufacture. For example, while the example systems, methods, apparatus, and articles of manufacturer have been described in conjunction with virtual machines, the example systems, methods, apparatus, and/or article of manufacture may operate within any structure that hosts virtual machines.
Although certain example systems, methods, apparatus and articles of manufacture have, been described herein, the scope of coverage of this patent is not limited thereto. On the contrary, this patent covers all systems, methods, apparatus and articles of manufacture fairly falling within the scope of the claims of this patent either literally or under the doctrine of equivalents.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2011/045939 | 7/29/2011 | WO | 00 | 1/24/2014 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2013/019185 | 2/7/2013 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5745735 | Cohn et al. | Apr 1998 | A |
5802062 | Gehani | Sep 1998 | A |
6321337 | Reshef | Nov 2001 | B1 |
6421739 | Holiday | Jul 2002 | B1 |
6732139 | Dillenberger | May 2004 | B1 |
6901522 | Buch | May 2005 | B2 |
6934952 | Sarkar | Aug 2005 | B2 |
6944699 | Bugnion et al. | Sep 2005 | B1 |
6970902 | Moon | Nov 2005 | B1 |
6985951 | Kubala | Jan 2006 | B2 |
7089558 | Baskey | Aug 2006 | B2 |
7127625 | Farkas et al. | Oct 2006 | B2 |
7174381 | Gulko | Feb 2007 | B2 |
7203944 | Van Rietschote | Apr 2007 | B1 |
7480908 | Tene | Jan 2009 | B1 |
7925923 | Hyser | Apr 2011 | B1 |
8175863 | Ostermeyer | May 2012 | B1 |
8181175 | McKee | May 2012 | B1 |
8185893 | Hyser | May 2012 | B2 |
8185894 | Watson | May 2012 | B1 |
8296760 | Magenheimer | Oct 2012 | B2 |
8341626 | Gardner | Dec 2012 | B1 |
8615579 | Vincent | Dec 2013 | B1 |
8732699 | Hyser | May 2014 | B1 |
8903888 | Hyser | Dec 2014 | B1 |
8910152 | Hyser | Dec 2014 | B1 |
9092250 | Hyser | Jul 2015 | B1 |
9141625 | Thornewell | Sep 2015 | B1 |
20020194389 | Worley, Jr. et al. | Dec 2002 | A1 |
20040010787 | Traut | Jan 2004 | A1 |
20040117539 | Bennett et al. | Jun 2004 | A1 |
20040186920 | Birdwell et al. | Sep 2004 | A1 |
20040193476 | Aerdts | Sep 2004 | A1 |
20050039180 | Fultheim | Feb 2005 | A1 |
20050060590 | Bradley et al. | Mar 2005 | A1 |
20050149940 | Calinescu | Jul 2005 | A1 |
20050166074 | Hack | Jul 2005 | A1 |
20050166075 | Hack | Jul 2005 | A1 |
20050246505 | Mckenney et al. | Nov 2005 | A1 |
20050251802 | Bozek | Nov 2005 | A1 |
20050278722 | Armstrong et al. | Dec 2005 | A1 |
20060023884 | Mckee | Feb 2006 | A1 |
20060041733 | Hyser | Feb 2006 | A1 |
20060075067 | Blackmore | Apr 2006 | A1 |
20060136913 | Sameske | Jun 2006 | A1 |
20060149906 | Misra | Jul 2006 | A1 |
20060195715 | Herington | Aug 2006 | A1 |
20060200819 | Cherkasova | Sep 2006 | A1 |
20060200820 | Cherkasova | Sep 2006 | A1 |
20060200821 | Cherkasova | Sep 2006 | A1 |
20060230407 | Rosu | Oct 2006 | A1 |
20060245665 | Lee | Nov 2006 | A1 |
20070043860 | Pabari | Feb 2007 | A1 |
20070067435 | Landis | Mar 2007 | A1 |
20070079307 | Dhawan | Apr 2007 | A1 |
20070083642 | Diedrich | Apr 2007 | A1 |
20070124474 | Margulis | May 2007 | A1 |
20070171921 | Wookey | Jul 2007 | A1 |
20070180280 | Bolan | Aug 2007 | A1 |
20070180448 | Low | Aug 2007 | A1 |
20070180450 | Croft | Aug 2007 | A1 |
20070186212 | Mazzaferri | Aug 2007 | A1 |
20070204266 | Beaty et al. | Aug 2007 | A1 |
20080082977 | Araujo et al. | Apr 2008 | A1 |
20080104587 | Magenheimer | May 2008 | A1 |
20080104608 | Hyser et al. | May 2008 | A1 |
20080222638 | Beaty | Sep 2008 | A1 |
20090007106 | Araujo, Jr. | Jan 2009 | A1 |
20090106409 | Murata | Apr 2009 | A1 |
20090106571 | Low et al. | Apr 2009 | A1 |
20090210527 | Kawato | Aug 2009 | A1 |
20090323706 | Germain | Dec 2009 | A1 |
20100153514 | Dabagh | Jun 2010 | A1 |
20100180275 | Neogi et al. | Jul 2010 | A1 |
20100242045 | Swamy | Sep 2010 | A1 |
20100250744 | Hadad et al. | Sep 2010 | A1 |
20100262974 | Uyeda | Oct 2010 | A1 |
20100333089 | Talwar et al. | Dec 2010 | A1 |
20110010515 | Ranade | Jan 2011 | A1 |
20110040575 | Wright | Feb 2011 | A1 |
20110099548 | Shen et al. | Apr 2011 | A1 |
20110131576 | Ikegaya | Jun 2011 | A1 |
20110145380 | Glikson | Jun 2011 | A1 |
20110161491 | Sekiguchi | Jun 2011 | A1 |
20110161851 | Barber et al. | Jun 2011 | A1 |
20110185007 | Sugawara | Jul 2011 | A1 |
20110270945 | Shiga | Nov 2011 | A1 |
20120016977 | Robertson | Jan 2012 | A1 |
20120066677 | Tang | Mar 2012 | A1 |
20120137285 | Glikson | May 2012 | A1 |
20130086272 | Chen | Apr 2013 | A1 |
20130339956 | Murase | Dec 2013 | A1 |
20140165063 | Shiva | Jun 2014 | A1 |
20140223556 | Bignon | Aug 2014 | A1 |
20150195141 | Luft | Jul 2015 | A1 |
20150277779 | Devarapalli | Oct 2015 | A1 |
Number | Date | Country |
---|---|---|
101449258 | Jun 2009 | CN |
101593133 | Dec 2009 | CN |
101876921 | Nov 2010 | CN |
101916207 | Dec 2010 | CN |
Entry |
---|
Raja Wasim Ahmad et al., A survey on virtual machine migration and server consolitation framework for cloud data centers, 2015, retrieved online on Oct. 25, 2016, pp. 1-15. Retrieved from the Internet: <URL: https://umexpert.um.edu.my/file/publication/00001293—119212.pdf>. |
Haikun Liu et al., Performance and Energy Modeling for Live Migration of Virtual Machine, ACM, Jun. 2011, retrieved online on Oct. 25, 2016, pp. 171-181. Retrieved from the Internet: <URL: http://delivery.acm.org/10.1145/2000000/1996154/p171-liu.pdf?ip=151.207.250.71&id=1996154&acc=ACTIVE%20SERVICE&key=C15944E53D0ACA63%2E4D4702B0C3E38B35%2E4D4702B0C3E>. |
Bose, S.K., Sundarrajan, S., “Optimizing Migration of Virtual machines across Data-Centers,” IEEE Xplore, Dec. 28, 2009, 306-313, (7 pages). |
Bozman, J.S., Chen, G.P., “Optimizing Hardware for X86 Server Virtualization,” IDC, Aug. 2009, 1-18, (18 pages). |
Korean Intellectual Property Office, International Search Report and Written Opinion, Mar. 16, 2012, Daejeon, Republic of Korea, 3 pages. |
European Patent Office, Extended European Search Report, Dec. 1, 2014, 10 pages, Munich, Germany. |
Wood T et al.: Sandpiper: Black-box and gray-box resource management for virtual machines, Computer Networks, Elsevier Science Publishers B.V., Amsterdam, NL, vol. 53, No. 17, Dec. 3, 2009, pp. 2923-2938, XP026765086. |
Hou et al., “A Genetic Algorithm for Multiprocessor Scheduling,” IEEE Transactions on Parallel and Distributed Systems, vol. 5, No. 2, Feb. 1994, pp. 1-8. |
Megow et al., “Stochastic Online Scheduling on Parallel Machine,” Springer-Verlag Berlin Heidelberg, 2005 (14 pages). |
Thefreedictionary, Virtual Machine, 2006 (3 pages). |
VMware Technology Network, “VMware VirtualCenter 1.2 Support Documentation,” http://www.vmware.com/support/vc12/doc/c13migrationover.html, Oct. 25, 2006 (8 pages). |
Wikipedia, Hypervisor, Sep. 2006 (2 pages). |
Wikipedia, Virtual Machine, Sep. 2006 (6 pages). |
YarKhan et al., “Experiments with Scheduling Using Simulated Annealing in a Grid Environment,” Springer-Verlag Berlin Heidelberg, pp. 232-242, 2002. |
Number | Date | Country | |
---|---|---|---|
20140165063 A1 | Jun 2014 | US |