Virtual resource scheduling for containers with migration

US2016378563A1 · US · A1

Patent metadata
FieldValue
Publication numberUS-2016378563-A1
Application numberUS-201514835758-A
CountryUS
Kind codeA1
Filing dateAug 26, 2015
Priority dateJun 25, 2015
Publication dateDec 29, 2016
Grant date

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A method for scheduling computing resources with container migration includes determining a resource availability for one or more hosts, a resource allocation for one or more virtual machines (VMs), and a resource usage for one or more containers. The method includes identifying the hosts on which VMs and containers can be consolidated based on resource availability. The method also includes calculating a target resource configuration for one or more VMs. The method further includes removing or adding resources to the VMs for which a target resource configuration was calculated to achieve the target resource configuration. The method further includes allocating the one or more VMs on the one or more hosts based on the resource availability of the one or more hosts, and allocating the one or more containers on the one or more VMs based on the resource configuration of each VM and the resource usage of each container.

First claim

Opening claim text (preview).

1 . A method for scheduling computing resources, comprising: determining a resource availability for one or more hosts, a resource allocation for one or more virtual machines (VMs), and a resource usage for one or more containers; identifying the one or more hosts on which VMs and containers can be consolidated based on the resource availability; calculating a target resource configuration for one or more VMs; removing or adding resources to each of the one or more VMs for which a target resource configuration was calculated to achieve the target resource configuration for each VM; allocating the one or more VMs on the one or more hosts based on the resource availability of the one or more hosts; and allocating the one or more containers on the one or more VMs based on the resource configuration of each VM and the resource usage of each container. 2 . The method of claim 1 , wherein the resource is memory. 3 . The method of claim 1 , wherein determining a resource usage for one or more containers further comprises summing a resource usage for each container and adding a grace factor. 4 . The method of claim 1 , wherein calculating a target resource configuration further comprises determining an upper limit of resource demand on a VM from one or more containers. 5 . The method of claim 1 , wherein identifying the one or more hosts on which VMs and containers can be consolidated based on the resource availability further comprises identifying hosts with enough resources to host the one or more containers. 6 . The method of claim 1 , wherein adding resources to a VM further comprises a hot add of resources to the VM. 7 . The method of claim 1 , wherein allocating the one or more containers on the one or more VMs further comprises migrating a container to a VM that has a matching operating system (OS) flavor by: performing a live migration of the container; performing a checkpoint/restore operation on the container; or killing and restarting the container. 8 . A non-transitory computer-readable storage medium containing a program which, when executed by one or more processors, performs operations for scheduling computing resources, the operations comprising: determining a resource availability for one or more hosts, a resource allocation for one or more virtual machines (VMs), and a resource usage for one or more containers; identifying the one or more hosts on which VMs and containers can be consolidated based on the resource availability; calculating a target resource configuration for one or more VMs; removing or adding resources to each of the one or more VMs for which a target resource configuration was calculated to achieve the target resource configuration for each VM; allocating the one or more VMs on the one or more hosts based on the resource availability of the one or more hosts; and allocating the one or more containers on the one or more VMs based on the resource configuration of each VM and the resource usage of each container. 9 . The non-transitory computer-readable storage medium of claim 8 , wherein the resource is memory. 10 . The non-transitory computer-readable storage medium of claim 8 , wherein determining a resource usage for one or more containers further comprises summing a resource usage for each container and adding a grace factor. 11 . The non-transitory computer-readable storage medium of claim 8 , wherein calculating a target resource configuration further comprises determining an upper limit of resource demand on a VM from one or more containers. 12 . The non-transitory computer-readable storage medium of claim 8 , wherein identifying the one or more hosts on which VMs and containers can be consolidated based on the resource availability further comprises identifying hosts with enough resources to host the one or more containers. 13 . The non-transitory computer-readable storage medium of claim 8 , wherein adding resources to a VM further comprises a hot add of resources to the VM. 14 . The non-transitory computer-readable storage medium of claim 8 , wherein allocating the one or more containers on the one or more VMs further comprises migrating a container to a VM that has a matching operating system (OS) flavor by: performing a live migration of the container; performing a checkpoint/restore operation on the container; or killing and restarting the container. 15 . A system, comprising: a processor; and a memory, wherein the memory includes a program executable in the processor to perform operations for scheduling computing resources, the operations comprising: determining a resource availability for one or more hosts, a resource allocation for one or more virtual machines (VMs), and a resource usage for one or more containers; identifying the one or more hosts on which VMs and containers can be consolidated based on the resource availability; calculating a target resource configuration for one or more VMs; removing or adding resources to each of the one or more VMs for which a target resource configuration was calculated to achieve the target resource configuration for each VM; allocating the one or more VMs on the one or more hosts based on the resource availability of the one or more hosts; and allocating the one or more containers on the one or more VMs based on the resource configuration of each VM and the resource usage of each container. 16 . The system of claim 15 , wherein the resource is memory. 17 . The system of claim 15 , wherein determining a resource usage for one or more containers further comprises summing a resource usage for each container and adding a grace factor. 18 . The system of claim 15 , wherein calculating a target resource configuration further comprises determining an upper limit of resource demand on a VM from one or more containers. 19 . The system of claim 15 , wherein adding resources to a VM further comprises a hot add of resources to the VM. 20 . The system of claim 15 , wherein allocating the one or more containers on the one or more VMs further comprises migrating a container to a VM that has a matching operating system (OS) flavor by: performing a live migration of the container; performing a checkpoint/restore operation on the container; or killing and restarting the container.

Assignees

Inventors

Classifications

  • Hypervisor-specific management and integration aspects · CPC title

  • Distribution of virtual machine instances; Migration and load balancing · CPC title

  • G06F9/5077Primary

    Logical partitioning of resources; Management or configuration of virtualized resources (specific details on emulation or internal functioning of virtual machines G06F9/455) · CPC title

  • resumption being on a different machine, e.g. task migration, virtual machine migration (G06F9/5088 takes precedence) · CPC title

  • Resource availability · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US2016378563A1 cover?
A method for scheduling computing resources with container migration includes determining a resource availability for one or more hosts, a resource allocation for one or more virtual machines (VMs), and a resource usage for one or more containers. The method includes identifying the hosts on which VMs and containers can be consolidated based on resource availability. The method also includes ca…
Who is the assignee on this patent?
Vmware Inc
What technology area does this patent fall under?
Primary CPC classification G06F9/45558. Mapped technology areas include Physics.
When was this patent published?
Publication date Thu Dec 29 2016 00:00:00 GMT+0000 (Coordinated Universal Time) (A1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).