Provisioning executable managed objects of a virtualized computing environment from non-executable managed objects

US11625257B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11625257-B2
Application numberUS-201615197552-A
CountryUS
Kind codeB2
Filing dateJun 29, 2016
Priority dateJun 29, 2016
Publication dateApr 11, 2023
Grant dateApr 11, 2023

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 managed object of a virtualized computing environment, which contains the runtime state of a parent virtual machine (VM) and can be placed in any host of the virtualized computing environment, is used for instantly cloning child VMs off that managed object. The managed object is not an executable object (i.e., the state of the managed object is static) and thus it does not require most of the overhead memory associated with a VM. As a result, this managed object can support instant cloning of VMs with a reduction in memory, storage, and CPU overhead relative to when a parent template VM is used.

First claim

Opening claim text (preview).

What is claimed is: 1. A method of provisioning virtual machines from a non-executable object of a plurality of non-executable objects in a virtualized computing environment having two or more host computers coupled to a shared storage, wherein managed objects of the virtualized computing environment are provisioned in the two or more host computers, the managed objects including (a) a plurality of executable objects capable of being executed on a processor of each of the two or more host computers, and (b) the plurality of non-executable objects, wherein a state of each non-executable object is static, further wherein the plurality of executable objects comprise a first virtual machine (VM) loaded into memory of a first host computer of the two or more host computers and executing on the processor of the first host computer, said method comprising: suspending execution of the first VM, and while suspended, capturing a snapshot of a runtime state of the first VM; creating an in-memory instance of the non-executable object on the first host computer from the captured snapshot, wherein the in-memory instance of the non-executable object contains the runtime state of the first VM, wherein the in-memory instance of the non-executable object includes a mapping between (a) guest physical memory page numbers of the first VM, and (b) machine memory page numbers of a kernel of the first host computer, and wherein the non-executable object is an object of the virtualized computing environment that is separately managed from the first VM; provisioning a second VM based on the in-memory instance of the non-executable object, without using any VM on the first host computer other than the second VM, to restore the runtime state of the first VM in the second VM; creating an on-disk instance of the non-executable object in the shared storage based on the in-memory instance of the non-executable object; creating a separate in-memory instance of the non-executable object on a second host computer of the two or more host computers based on the on-disk instance of the non-executable object in the shared storage; and provisioning a third VM on the second host computer from the separate in-memory instance of the non-executable object. 2. The method of claim 1 , wherein the in-memory instance of the non-executable object is maintained in the memory of the first host computer and memory space allocated to the non-executable object is reclaimable. 3. The method of claim 1 , wherein the runtime state of the first VM includes memory pages of the first VM and states of devices of the first VM. 4. The method of claim 1 , wherein the second VM is provisioned in the first host computer. 5. A non-transitory computer readable medium comprising instructions, which when executed by two or more host computers coupled to a shared storage, cause the two or more host computers to perform a method of provisioning virtual machines from a non-executable object of a plurality of non-executable objects in a virtualized computing environment, wherein managed objects of the virtualized computing environment are provisioned in the two or more host computers, the managed objects including (a) a plurality of executable objects capable of being executed on a processor of each of the two or more host computers, and (b) the plurality of non-executable objects, wherein a state of each non-executable object is static, further wherein the plurality of executable objects comprise a first virtual machine (VM) loaded into memory of a first host computer of the two or more host computers and executing on the processor of the first host computer, said method comprising: suspending execution of the first VM, and while suspended, capturing a snapshot of a runtime state of the first VM; creating an in-memory instance of the non-executable object on the first host computer from the captured snapshot, wherein the in-memory instance of the non-executable object contains the runtime state of the first VM, wherein the in-memory instance of the non-executable object includes a mapping between (a) guest physical memory page numbers of the first VM, and (b) machine memory page numbers of a kernel of the first host computer, and wherein the non-executable object is an object of the virtualized computing environment that is separately managed from the first VM; provisioning a second VM based on the in-memory instance of the non-executable object, without using any VM on the first host computer other than the second VM, to restore the runtime state of the first VM in the second VM; creating an on-disk instance of the non-executable object in the shared storage based on the in-memory instance of the non-executable object; creating a separate in-memory instance of the non-executable object on a second host computer of the two or more host computers based on the on-disk instance of the non-executable object in the shared storage; and provisioning a third VM on the second host computer from the separate in-memory instance of the non-executable object. 6. The non-transitory computer readable medium of claim 5 , wherein the in-memory instance of the non-executable object is maintained in the memory of the first host computer and memory space allocated to the non-executable object is reclaimable. 7. The non-transitory computer readable medium of claim 5 , wherein the runtime state of the first VM includes memory pages of the first VM and states of devices of the first VM. 8. The non-transitory computer readable medium of claim 5 , wherein the second VM is provisioned in the first host computer. 9. A virtualized computing environment comprising a cluster of host computers, including a first host computer and a second host computer coupled to a shared storage, wherein managed objects of the virtualized computing environment are provisioned in the cluster of host computers, the managed objects including (a) a plurality of executable objects capable of being executed on a processor of each of the first and second host computers, and (b) a plurality of non-executable objects, wherein a state of each non-executable object is static, further wherein the plurality of executable objects comprise a first virtual machine (VM) loaded into memory of the first host computer and executing on the processor of the first host computer, the cluster of host computers configured to perform a method of provisioning virtual machines from a non-executable object of the plurality of non-executable objects, said method comprising: suspending execution of the first VM, and while suspended, capturing a snapshot of a runtime state of the first VM; creating an in-memory instance of the non-executable object on the first host computer from the captured snapshot, wherein the in-memory instance of the non-executable object contains the runtime state of the first VM, wherein the in-memory instance of the non-executable object includes a mapping between (a) guest physical memory page numbers of the first VM, and (b) machine memory page numbers of a kernel of the first host computer, and wherein the non-executable object is an object of the virtualized computing environment that is separately managed from the first VM; provisioning a second VM based on the in-memory instance of the non-executable object, without using any VM on the first host computer other than the second VM, to restore the runtime state of the first VM in the second VM; creating an on-disk instance of the non-executable object in the shared storage based on the in-memory instance of the non-executable object; creating a separate in-memory instance of the non-executable object on the second host computer based on the on-disk instance of the non-executable object in the shared storage;

Assignees

Inventors

Classifications

  • Hypervisor-specific management and integration aspects · CPC title

  • Memory management, e.g. access or allocation · CPC title

  • Creating, deleting, cloning virtual machine instances · 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 US11625257B2 cover?
A managed object of a virtualized computing environment, which contains the runtime state of a parent virtual machine (VM) and can be placed in any host of the virtualized computing environment, is used for instantly cloning child VMs off that managed object. The managed object is not an executable object (i.e., the state of the managed object is static) and thus it does not require most of the…
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 Tue Apr 11 2023 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 10 related publications on this page (citations in our corpus or others sharing the same primary CPC).