Transparent host-side caching of virtual disks located on shared storage

US9983998B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9983998-B2
Application numberUS-201615145109-A
CountryUS
Kind codeB2
Filing dateMay 3, 2016
Priority dateAug 27, 2012
Publication dateMay 29, 2018
Grant dateMay 29, 2018

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.

Techniques for using a cache to accelerate virtual machine (VM) I/O are provided. In one embodiment, a host system can intercept an I/O request from a VM running on the host system, where the I/O request is directed to a virtual disk residing on a shared storage device. The host system can then process the I/O request by accessing a cache that resides on one or more cache devices directly attached to the host system, where the accessing of the cache is transparent to the VM.

First claim

Opening claim text (preview).

What is claimed is: 1. A host system comprising: a processor; one or more cache devices; and a non-transitory computer readable medium having stored thereon program code that, when executed by the processor, causes the processor to: intercept an I/O request from a VM running on the host system, the I/O request being directed to a virtual disk residing on a shared storage device; and process the I/O request by accessing a cache that resides on the one or more cache devices, the accessing of the cache being transparent to a guest operating system of the VM, wherein the VM or the virtual disk is allocated a portion of the cache when the VM is powered on, and wherein the portion of the cache allocated to the VM or the virtual disk is freed when the VM is powered off or suspended. 2. The host system of claim 1 wherein the program code that causes the processor to process the I/O request by accessing the cache comprises program code that causes the processor to invoke a caching module that has been preconfigured for use with the VM or the virtual disk. 3. The host system of claim 2 wherein the caching module is a modular component that is implemented by a third-party developer. 4. The host system of claim 1 wherein the cache is spread across a plurality of cache devices that are pooled into a single logical resource by applying a common file system to the plurality of cache devices. 5. The host system of claim 4 wherein the plurality of cache devices are heterogeneous devices. 6. The host system of claim 1 wherein the portion of the cache allocated to the VM or the virtual disk when the VM is powered on has a preconfigured minimum size and a preconfigured maximum size. 7. The host system of claim 1 wherein the allocated portion is further freed when the VM is migrated to another host system. 8. The host system of claim 1 wherein the one or more cache devices are distinct from the shared storage device. 9. A method for using a cache to accelerate virtual machine (VM) I/O, the method comprising: intercepting an I/O request from a VM running on a host system, the I/O request being directed to a virtual disk residing on a shared storage device; and processing the I/O request by accessing a cache that resides on one or more cache devices directly attached to the host system, the accessing of the cache being transparent to a guest operating system of the VM, wherein the VM or the virtual disk is allocated a portion of the cache when the VM is powered on, and wherein the portion of the cache allocated to the VM or the virtual disk is freed when the VM is powered off or suspended. 10. The method of claim 9 wherein processing the I/O request by accessing the cache comprises invoking a caching module that has been preconfigured for use with the VM or the virtual disk. 11. The method of claim 10 wherein the caching module is a modular component that is implemented by a third-party developer. 12. The method of claim 9 wherein the cache is spread across a plurality of cache devices that are pooled into a single logical resource by applying a common file system to the plurality of cache devices. 13. The method of claim 12 wherein the plurality of cache devices are heterogeneous devices. 14. The method of claim 9 wherein the portion of the cache allocated to the VM or the virtual disk when the VM is powered on has a preconfigured minimum size and a preconfigured maximum size. 15. The method of claim 9 wherein the allocated portion is further freed when the VM is migrated to another host system. 16. The method of claim 9 wherein the one or more cache devices are distinct from the shared storage device. 17. A non-transitory computer readable storage medium having stored thereon computer software executable by a processor of a host system, the computer software embodying a method for using a cache to accelerate VM I/O, the method comprising: intercepting an I/O request from a VM running on the host system, the I/O request being directed to a virtual disk residing on a shared storage device; and processing the I/O request by accessing a cache that resides on one or more cache devices directly attached to the host system, the accessing of the cache being transparent to a guest operating system of the VM, wherein the VM or the virtual disk is allocated a portion of the cache when the VM is powered on, and wherein the portion of the cache allocated to the VM or the virtual disk is freed when the VM is powered off or suspended. 18. The non-transitory computer readable storage medium of claim 17 wherein processing the I/O request by accessing the cache comprises invoking a caching module that has been preconfigured for use with the VM or the virtual disk. 19. The non-transitory computer readable storage medium of claim 18 wherein the caching module is a modular component that is implemented by a third-party developer. 20. The non-transitory computer readable storage medium of claim 17 wherein the cache is spread across a plurality of cache devices that are pooled into a single logical resource by applying a common file system to the plurality of cache devices. 21. The non-transitory computer readable storage medium of claim 20 wherein the plurality of cache devices are heterogeneous devices. 22. The non-transitory computer readable storage medium of claim 17 wherein the portion of the cache allocated to the VM or the virtual disk when the VM is powered on has a preconfigured minimum size and a preconfigured maximum size. 23. The non-transitory computer readable storage medium of claim 17 wherein the allocated portion is further freed when the VM is migrated to another host system. 24. The non-transitory computer readable storage medium of claim 17 wherein the one or more cache devices are distinct from the shared storage device.

Assignees

Inventors

Classifications

  • Latency reduction · CPC title

  • Improving I/O performance · CPC title

  • Hypervisor-specific management and integration aspects · CPC title

  • Allocation or management of cache space · CPC title

  • by allocating resources to storage systems · 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 US9983998B2 cover?
Techniques for using a cache to accelerate virtual machine (VM) I/O are provided. In one embodiment, a host system can intercept an I/O request from a VM running on the host system, where the I/O request is directed to a virtual disk residing on a shared storage device. The host system can then process the I/O request by accessing a cache that resides on one or more cache devices directly attac…
Who is the assignee on this patent?
Vmware Inc
What technology area does this patent fall under?
Primary CPC classification G06F12/0866. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue May 29 2018 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 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).