[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

US20120174096A1 - Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes - Google Patents

Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes Download PDF

Info

Publication number
US20120174096A1
US20120174096A1 US13/247,693 US201113247693A US2012174096A1 US 20120174096 A1 US20120174096 A1 US 20120174096A1 US 201113247693 A US201113247693 A US 201113247693A US 2012174096 A1 US2012174096 A1 US 2012174096A1
Authority
US
United States
Prior art keywords
virtual machine
storage volumes
attach
virtual
hypervisor
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US13/247,693
Inventor
Matthew Conover
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
CloudVolumes Inc
Original Assignee
CloudVolumes Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by CloudVolumes Inc filed Critical CloudVolumes Inc
Priority to US13/247,693 priority Critical patent/US20120174096A1/en
Assigned to SNAPVOLUMES, INC. reassignment SNAPVOLUMES, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CONOVER, MATTHEW
Publication of US20120174096A1 publication Critical patent/US20120174096A1/en
Priority to US14/458,586 priority patent/US9639385B2/en
Assigned to CLOUDVOLUMES, INC. reassignment CLOUDVOLUMES, INC. CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: SNAPVOLUMES, INC.
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45579I/O management, e.g. providing access to device drivers or storage

Definitions

  • a “virtual machine” is a virtualized copy of a computer system, with virtual hardware (including disk controller, network card, etc.). Frequently, running within the virtual machine is a full operating system. These virtual machines run on a physical host server known as a hypervisor. The hypervisor abstracts the physical hardware of the host server so that the virtual machine sees virtual hardware regardless of what the underlying hardware actually is.
  • the storage volumes that appear within the virtual machine are virtualized storage volumes provided by the hypervisor. The storage volumes visible from within the virtual machine can come from multiple sources.
  • Virtual machines may be centrally managed in an enterprise and used by different departments. Because of this, the purpose of the virtual machine (and the software used on it) may change over time. Managing application usage across the enterprise, such as uninstalling a large application and installing another application can be time consuming and very resource intensive.
  • a method of operating a data management system includes starting a virtual machine software agent running within a virtual machine based on an attach-triggering event, determining selected volumes to be attached to the virtual machine based on the attach-triggering event, and dynamically attaching the selected volumes to the virtual machine.
  • FIG. 1 illustrates a data management system according to one example.
  • FIG. 2 illustrates the operation of a data management system.
  • FIG. 3 illustrates the operation of a data management system.
  • FIG. 4 illustrates a data management system
  • a virtual machine software agent (hereinafter referred to as a VM agent) running inside a virtual machine contacts a virtual machine manager (hereinafter referred to as a VM manager) to notify the VM manager of an event which results in the VM manager requesting a hypervisor to dynamically attach a storage volume to the virtual machine when certain conditions are met.
  • VM agent virtual machine software agent
  • a VM manager virtual machine manager
  • These conditions can include the identification of the user, which may in turn identify groups to which the user belongs, user preferences, etc.
  • ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ ⁇
  • FIG. 1 illustrates a system 100 configured to load data and/or applications to one or more target virtual machines 110 A, 110 B from storage volumes that are attached by a hypervisor 115 .
  • the hypervisor 115 may be a computing device or group of computing devices on which the target virtual machines 110 A, 110 B run. Although shown as a single computing device, the hypervisor 115 may operate on as many computing devices and/or in as many environments as desired.
  • the system 100 may also include VM agents 120 A, 120 B running within the virtual machines 110 A, 110 B.
  • the VM agent 120 is configured to interact with a VM manager 130 .
  • the VM manager 130 is a virtual appliance running on or supported by the hypervisor 115 . It will be appreciated that the VM manager 130 may also be a separate appliance as desired, as shown schematically in FIG. 1 .
  • the VM manager 130 determines which of various storage volumes in a storage repository 140 , including writable storage volume(s) 150 and application volume(s) 160 , should be attached to the virtual machines 110 A, 110 B.
  • the VM manager 130 then causes the hypervisor 115 to attach the selected writable storage volumes 150 and application storage volumes 160 to the appropriate target virtual machine 110 A, 110 B.
  • the attached storage volumes 170 may then be attached to the target virtual machines 110 A, 110 B.
  • the attached storage volumes 170 are shown within the target virtual machines 110 to emphasize the attachment of the selected storage volumes 170 , though it will be appreciated that the selected storage volume 170 may not actually be transferred into the target virtual machines 170 .
  • the disk blocks in the storage volume would only be accessed by the hypervisor and transferred into the virtual machine upon a disk read event from the virtual machine.
  • the system 100 is configured to make the application storage volume 160 , including one or more applications 162 stored thereon, available to a plurality of virtual machines (represented schematically as the virtual machines 110 A, 110 B) concurrently.
  • the hypervisor 115 abstracts the physical hardware of the host computing device so that the virtual machine sees virtual hardware regardless of what the underlying hardware actually is.
  • the application storage volume 160 is mounted by the hypervisor 115 to thereby allow the virtual machines 110 A, 110 B to access the application 162 on the application storage volume 160 through the hypervisor 115 .
  • the storage volume 160 is concurrently attached by hypervisor 115 to virtual machines 110 A, 110 B the storage volume 160 would appear as a locally attached hard disk (such as a SCSI disk) within the virtual machine.
  • the application 162 may be stored on the application storage volume 160 as a read only volume.
  • the virtual machines 110 A, 110 B may be able to only access and execute the application 162 rather than modify the application.
  • the application storage volume 160 may be attached as a non-persistent writable volume to enable it to be concurrently shared. In this way, the application or its data may be modified by virtual machine 110 A, 110 B but the changes will be discarded once the application storage volume 160 is detached from the virtual machine.
  • Such configurations may allow the application 162 to be accessed by the virtual machines 110 A, 110 B concurrently.
  • the hypervisor 115 can attach the application 162 to one or more of the virtual machines 110 A, 110 B concurrently as desired.
  • the attachment of the application 162 to the virtual machine may be performed in any desired manner.
  • the application storage volume 160 can be statically attached to one of the virtual machines 110 A, 110 B, in which case it will remain permanently attached to the virtual machine 110 A, 110 B.
  • the VM agents 120 A, 120 B running in the virtual machines 110 A, 110 B can dynamically request the VM manager 130 to request the hypervisor 115 to attach the application storage volume 160 on demand. This may be desirable, for example, to enable an IT administrator to track software license compliance by tracking how many virtual machines are concurrently using an application. Such a configuration may allow the system to load applications and data into the target virtual machine automatically or dynamically as desired.
  • a user or administrator could directly interact with the VM manager 130 to request an application storage volume be attached to or detached from a plurality of virtual machines on demand. To this end, the VM manager 130 could expose a management interface for users and administrators to interact with.
  • FIG. 2 is a flowchart illustrating a method 200 for loading applications and data into a virtual machine.
  • the method begins at step 210 with a VM agent responding to the detection of an attach-triggering event.
  • volumes to be attached to the target virtual machine are identified.
  • the selected volumes are dynamically attached to the target virtual machine. Attaching the volume dynamically may allow for sharing an application across multiple virtual machines simultaneously.
  • FIG. 3 is a flowchart illustrating a method 300 for sharing an application across multiple virtual machines simultaneously. As shown in FIG. 3 , the method begins at step 310 by placing an application on an application storage volume. In at least one example, placing the application on the application storage volume includes setting the application storage volume state to read only.
  • a hypervisor associated with a plurality of virtual machines attaches the application storage volume to each virtual machine concurrently.
  • the application storage volume including applications stored thereon, is attached to selected virtual machines. This attachment may be static or dynamic as desired.
  • the method at step 330 includes making the applications available to a plurality of virtual machines concurrently.
  • the VM agent in cooperation with the volume detector described later, can detect the presence of the new applications and automatically start the applications contained within the application storage volume or notify the user that new applications are available.
  • FIG. 4 illustrates a system 400 that includes storage repository 410 , a plurality of virtual machines 420 A- 420 C executed by a hypervisor 430 , and a virtual machine manager (VM manager) 440 .
  • VM agents 422 A- 422 C running inside the virtual machines 420 contacts the VM manager 440 to request the hypervisor 430 to dynamically attach one or more of the storage volumes 412 - 416 or applications 419 A- 419 D within an application repository 418 when certain conditions are met.
  • the VM agents 422 A- 422 C in various embodiments, could be a Windows service, a Unix daemon, or a script.
  • the VM agents 422 A- 422 C are configured to detect when a specific event happens (an “attach-triggering event”) and respond to it by informing the VM manager.
  • An attach-triggering event could be that the operating system in the associated virtual machine 420 A- 420 C is booting (“VM startup”), user has logged into the operating system of the VM (“user logon”), or some other identifiable event.
  • VM agent 422 A running within virtual machine 420 A will be described. It will be appreciated that the discussion of the virtual machine 420 A and VM agent 422 A may be equally applicable to the other virtual machines 420 B- 420 C and VM agents 422 B- 422 C.
  • the VM manager 440 may be a part of the VM agent 422 A itself. In other examples, the VM manager 440 may reside on a separate physical computer or a separate virtual machine that the VM agent 422 A communicates with over a network.
  • the VM manager 440 may be responsible for deciding which of storage volumes 412 - 416 and/or application volumes 419 A- 419 D should be attached based on the certain criterion. If the attach-triggering event is a VM startup, the VM manager 440 may look for storage volumes that should be applied based on the virtual machine. If the attach-triggering event is a user logon, the VM manager 440 may look for storage volumes that should be applied based on the user.
  • the VM manager 440 When the attach-triggering event is a VM startup, the VM manager 440 will look for a writable storage volume associated with the virtual machine 422 A (computer volume 412 ) and any of the application volumes 419 A- 419 D that should be dynamically provided to the virtual machine 422 A from the application repository 418 . The sharing of the applications 419 A- 419 D across the virtual machines 420 A- 420 C will be discussed in more detail at an appropriate point hereinafter.
  • the VM manager 440 can store this information in its internal memory, in a database (such as Configuration Database 448 ) or in a directory (such as “Active Directory”).
  • the VM manager 440 When the attach-triggering event is a user logon, the VM manager 440 will look for a writable storage volume associated with the user (user volume 414 ) and any application volumes, such as the application volumes 419 A- 419 D in the application repository 418 .
  • the user volume 414 may include user-installed applications, Windows profile (home directory), preferences and settings, files, and registry keys (inside of a registry hive). Such a configuration may help the system 400 provide a persistent virtual environment for each user in an efficient manner.
  • the storage volumes 412 - 416 and application volumes 419 A- 419 D to be attached to the virtual machine 420 A can be selected based on individual identity (a user volume belonging to a particular user) or based on a group (if the virtual machine 422 A is a member of a particular group of computers, or if the user is a member of a group of users). For example, if all users in the engineering group need a particular application, such as Microsoft Visual Studio, when a user who is a member of the engineering group logs into the virtual machine 420 A, the VM agent 422 A will inform the VM manager 440 of the user logon event.
  • the VM manager 440 will then check for the user volume 414 belonging to the user, any application volumes 419 A- 419 D belonging to the user, and any application volumes 419 A- 419 D belonging to the groups the user belongs to.
  • the VM agent 422 A communicates with the VM manager 440 .
  • the VM manager 440 is responsible for deciding which of the appropriate storage volumes 412 - 418 and/or applications 419 A- 419 D should be attached to the virtual machine 420 A.
  • attached volumes described above may contain a file system with files and registry keys.
  • the registry keys can be stored in a file or directory located on the attached volume.
  • this file format can be a one or more registry hive files (just as the HKEY_CURRENT_USER registry hive is a file named ntuser.dat located within the user's profile).
  • the registry keys could be represented in a database or a proprietary format describing registry metadata.
  • VM agents 422 A- 422 C shown in FIG. 4 can detect when the volume has been attached and enumerate the registry keys on the volume (whether represented as a hive or a set of directories and files on the volume).
  • the VM agent will look for known load points, such as HKEY_LOCAL_MACHINE ⁇ CurrentControlSet ⁇ Services, to locate programs, services, and drivers to be started. This process of locating programs, services, and drivers to be launched by the VM agents mimics what the operating system would normally do upon starting up.
  • all of the programs, services, and drivers configured located on those volumes will be made available and start as if they were installed traditionally within the virtual machine.
  • a driver (a mini-filter driver or a file system filter driver, familiar to those skilled in the art) will detect attempts to write to non-persistent file systems (such as the C: ⁇ drive) and will redirect the access to an attached, writable volume dedicated to the user or virtual machine.
  • non-persistent file systems such as the C: ⁇ drive
  • the VM manager 440 directly or indirectly contacts the hypervisor 430 and requests for the storage volumes 412 - 416 and/or application volumes 419 A- 419 D to be attached to the virtual machine 420 A.
  • the VM manager 440 could directly request the storage volumes 412 - 416 and/or application volumes 419 A- 419 D to be attached to the virtual machine 420 A by connecting to the hypervisor 430 (such as VMware ESX server).
  • the VM manager 440 could indirectly request the storage volumes 412 - 416 and/or the application volumes 419 A- 419 D to be attached to the virtual machine 420 A by connecting to a virtual datacenter manager 450 responsible for managing several hypervisors (such as a VMware vCenter server). Further, application brokers may be utilized with the system to help control and/or optimize the management of data by the system 400 , as will be discussed at appropriate locations hereinafter.
  • a virtual datacenter manager 450 responsible for managing several hypervisors (such as a VMware vCenter server).
  • application brokers may be utilized with the system to help control and/or optimize the management of data by the system 400 , as will be discussed at appropriate locations hereinafter.
  • the computer volumes 412 and user volumes 414 are types of writable storage.
  • the computer volumes 412 and user volumes 414 may be specific to each user or virtual machine.
  • the application volumes 419 A- 419 D in the application repository may be read-only and can be shared by multiple virtual machines concurrently.
  • these application volumes could be writable but non-persistent, such that the changes are discarded once the volume is detached from the virtual machine. Exemplary sharing of the application volumes 419 A- 419 D will now be discussed in more detail.
  • the virtual machine agents 422 A- 422 C can be configured to either (1) directly request the hypervisor 430 to request selected application volumes 419 A- 419 D to be dynamically attached or (2) indirectly request the application volumes 419 A- 419 D to be attached by first communicating with VM manager 440 . Communicating with the VM manager 440 may reduce the exposure of the credentials of the hypervisor 430 within each virtual machine.
  • an application broker 460 can be consulted which will choose the best location to source the application volumes 419 A- 419 D from when there is more than one copy of the application volumes available.
  • the application broker could be responsible for communicating the hypervisor to directly attach the application volume selected.
  • the application broker merely points to the best location to source the application storage volume from and leaves the responsibility to the VM manager to actually instruct the hypervisor to attach the relevant application storage volume.
  • the application can be placed into multiple, redundant storage volumes.
  • the application could be located on two different storage volumes within two different data stores within a data center.
  • the application broker 460 may be operatively associated with the application repository 418 to allow the application broker 460 to track availability of and latency to the different application storage volumes containing a selected application.
  • the application broker 460 can dynamically decide which application volumes 419 A- 419 D to attach based on the aforementioned latency and availability checks. In other embodiments, numerous strategies could be used by the application broker 460 to select an application volume such as round-robin, least recently used storage application volume, lowest latency, etc.
  • each of the virtual machines 420 A- 420 C may include a volume detector 424 A- 424 C respectively.
  • the volume detector 424 A- 424 C can be configured to detect when a new storage volume has been attached to the virtual machine 420 A- 420 C. In one embodiment, this can be a file system filter driver. In another embodiment, this may be a file system mini-filter driver. In another embodiment, this can be a Windows service configured to detect when new storage devices have been attached.
  • a volume overlay software agent will be invoked (the volume overlay agents 426 A- 426 C).
  • the volume overlay agents 426 A- 426 C may be part of the volume detectors 424 A- 424 C or may be a separate driver as shown.
  • Each of the volume overlay agents 426 A- 426 C is responsible for exposing the data and applications contained in the storage repository 410 and making it available to the corresponding virtual machine 420 A- 420 C.
  • the volume overlay agents 426 A- 426 C may accomplish this by overlaying the content (such as files and registry keys) on top of the existing virtual machines 420 A- 420 C so that the content can be seamlessly integrated into the virtual machine environments.
  • the VM agents 422 A- 422 C can enumerate the contents of the volume and automatically start the relevant services or drivers.
  • the VM agent can enumerate all Start registry values to look for services contained in the KEY_LOCAL_MACHINE ⁇ SYSTEM ⁇ CurrentControlSet ⁇ Services subtree that should be automatically started and invoke the relevant APIs (such as ZwLoadDriver and Start Service).
  • the VM agents 422 A- 422 C are also configured to respond to detection of a specific triggering event (“detach-triggering event”).
  • Detach-triggering events include a virtual machine being powered off or a user logging off.
  • the VM agent contacts the VM manager to report the detach-triggering event.
  • the VM manager may then directly or indirectly request the hypervisor 430 to detach the storage volume from the corresponding virtual machine 420 A- 420 C. To this point, attachment of the application storage volumes has been discussed generally.
  • storage will be dynamically attached to the virtual machine without the need to reboot the virtual machine. Once the storage is attached to the virtual machine, the storage will be directly accessible from within the virtual machine. This enables a non-persistent virtual machine to function as if it is a persistent virtual machine.
  • the storage dynamically attached to the virtual machine utilized by this invention can be in any form supported by the hypervisor and operating system of the virtual machine.
  • the storage dynamically attached to the virtual machine may contain multiple partitions, volumes, and file systems. Storage concepts such as partitions, volumes, and file systems are well-known to skilled artisans and outside the scope of this invention.
  • the storage dynamically attached to the virtual machine can be attached through a network (using protocols such as iSCSI or Fibre Channel which reference storage by LUNs, or logical unit numbers).
  • the storage dynamically attached to the virtual machine is directly attached from physical volumes (raw device mapping) such as a hard disk and hard disk partitions and the hypervisor with pass through access from the virtual machine directly to the hardware.
  • the storage dynamically attached to the virtual machine can be a virtual device represented by a file (an ISO representing a virtual CD-ROM or a virtual hard disk file such as the VMDK and VHD file formats which represent a disk).
  • the storage dynamically attached to the virtual machine does not need to be contained within a single physical device or single virtual device represented by a file.
  • the storage may be in the form of different virtual hard disk files or physical devices attached simultaneously which represent “physical volumes” within the virtual machine. These physical volumes will be composed of logical volumes.
  • This approach known as storage virtualization, allows logical volumes to be abstracted from the underlying physical storage. A logical volume (itself containing a file system) spread out across multiple physical volumes can lead to improved redundancy and performance where logical volumes.
  • Technology to provide this storage virtualization such as Redundant Array of Independent Disks (RAID for short), logical volumes, and physical volumes, are well-known to skilled artisans and outside the scope of this invention.
  • volume and “volumes” will be used to refer to logical storage volumes visible within the virtual machine including (1) the volume containing the operating system (typically the C: drive for the Windows® operating system) and (2) any dynamically attached storage previously described above.
  • the operating system typically the C: drive for the Windows® operating system
  • any dynamically attached storage previously described above.
  • the volumes associated with the user are detached.
  • the volumes associated with the user are attached to the new virtual machine.
  • the user's writable volume containing the user's data and user-installed applications and any application volumes containing applications assigned to the user will remain available to the user regardless of which virtual machine the user is using.
  • a new volume can be created that is a differential disk or a delta disk of the writable volume. If a user logs in to two separate virtual machines, each would receive a separate copy of the user's writable volume that can be written to. Only the modifications go into the delta disk. Once the user logs off the virtual machine, the data in the delta disk would be reintegrated into the original volume. If the changes made by the user on the two different virtual machines conflict (such that the changes to the two separate linked clones modify the same data), a software policy can determine the appropriate way to resolve the conflict. A software policy for conflict resolution could be, for example, to favor newer changes such that the delta disk with the most recent modification will pre-empt any older, overlapping modification from a different delta disk.
  • This invention thus enables applications, services, and drivers to be installed on separate volumes that are dynamically attached after a user has logged in or after a virtual machine has booted up as if the applications, services, or drivers were part of the original virtual machine.
  • This enables the virtual machine to be a minimal virtual machine which only needs to have the VM agents to support dynamically attached volumes. All other programs can be made available at run-time (after a user logs in) depending on which user logs in or which group the user logs into. While an engineer might need a different set of applications than an accountant, they can share the same set of pooled, non-persistent virtual machines.
  • the IT department can update software located in the volumes. IT staff can also ensure license compliance (by determining how many users are utilizing a given volume containing the licensed software).
  • storage volumes within the virtual machines contain data items that need to be accessed. Unfortunately, accessing the underlying contents of a storage volume can be very resource intensive, reducing the performance of a virtual machine and other operations within a virtual machine environment.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

Systems, methods, and software are described herein for operating a data management system, including a virtual machine agent running within a virtual machine responding to an attach-triggering event, determining selected storage volumes to be attached to the virtual machine based on a request generated by the virtual agent in response to the attach-triggering event, and dynamically attaching the selected storage volumes to the virtual machine.

Description

    RELATED APPLICATIONS
  • This application claims the benefit of U.S. Provisional Application Ser. No. 61/428,690 filed Dec. 30, 2010 and entitled “METHOD AND APPARATUS TO LOAD USER DATA AND APPLICATION INTO A VIRTUAL DESKTOP USING DYNAMICALLY ATTACHED STORAGE,” U.S. Provisional Application Ser. No. 61/475,832 filed Apr. 14, 2011 and entitled “SYSTEMS AND METHODS TO LOAD APPLICATIONS AND APPLICATION DATA INTO A VIRTUAL MACHINE USING HYPERVISOR-ATTACHED VOLUMES,” and U.S. Provisional Application Ser. No. 61/475,881 filed Apr. 15, 2011 and entitled “SYSTEMS AND METHODS TO CONCURRENTLY SHARE APPLICATIONS ACROSS MULTIPLE VIRTUAL MACHINES,” the disclosures of which are hereby incorporated by reference in their entireties.
  • BACKGROUND OF THE INVENTION
  • A “virtual machine” is a virtualized copy of a computer system, with virtual hardware (including disk controller, network card, etc.). Frequently, running within the virtual machine is a full operating system. These virtual machines run on a physical host server known as a hypervisor. The hypervisor abstracts the physical hardware of the host server so that the virtual machine sees virtual hardware regardless of what the underlying hardware actually is. The storage volumes that appear within the virtual machine are virtualized storage volumes provided by the hypervisor. The storage volumes visible from within the virtual machine can come from multiple sources.
  • Virtual machines may be centrally managed in an enterprise and used by different departments. Because of this, the purpose of the virtual machine (and the software used on it) may change over time. Managing application usage across the enterprise, such as uninstalling a large application and installing another application can be time consuming and very resource intensive.
  • OVERVIEW
  • A method of operating a data management system includes starting a virtual machine software agent running within a virtual machine based on an attach-triggering event, determining selected volumes to be attached to the virtual machine based on the attach-triggering event, and dynamically attaching the selected volumes to the virtual machine.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 illustrates a data management system according to one example.
  • FIG. 2 illustrates the operation of a data management system.
  • FIG. 3 illustrates the operation of a data management system.
  • FIG. 4 illustrates a data management system.
  • DESCRIPTION
  • Systems and methods are provided herein to make applications and application data available within a virtual machine (VM) at runtime without a reboot. In at least one example, a virtual machine software agent (hereinafter referred to as a VM agent) running inside a virtual machine contacts a virtual machine manager (hereinafter referred to as a VM manager) to notify the VM manager of an event which results in the VM manager requesting a hypervisor to dynamically attach a storage volume to the virtual machine when certain conditions are met. These conditions can include the identification of the user, which may in turn identify groups to which the user belongs, user preferences, etc. Based on these user and group specific criteria, several types of storage volumes are provided to the user, which may allow the system to provide a persistent virtual environment for the user in an efficient manner, as well as providing applications in an efficient manner as appropriate across the network. Similarly, the storage volumes that should be attached to a virtual machine could be based on the virtual machine rather than the user. In addition, the virtual machine could belong to a group of related virtual machines. For example, a virtual machine could belong to a web server group that is associated with a storage volume containing a web server application.
  • FIG. 1 illustrates a system 100 configured to load data and/or applications to one or more target virtual machines 110A, 110B from storage volumes that are attached by a hypervisor 115. In at least one example, the hypervisor 115 may be a computing device or group of computing devices on which the target virtual machines 110A, 110B run. Although shown as a single computing device, the hypervisor 115 may operate on as many computing devices and/or in as many environments as desired.
  • The system 100 may also include VM agents 120A, 120B running within the virtual machines 110A, 110B. The VM agent 120 is configured to interact with a VM manager 130. In at least one example, the VM manager 130 is a virtual appliance running on or supported by the hypervisor 115. It will be appreciated that the VM manager 130 may also be a separate appliance as desired, as shown schematically in FIG. 1. In the illustrated example, the VM manager 130 determines which of various storage volumes in a storage repository 140, including writable storage volume(s) 150 and application volume(s) 160, should be attached to the virtual machines 110A, 110B. The VM manager 130 then causes the hypervisor 115 to attach the selected writable storage volumes 150 and application storage volumes 160 to the appropriate target virtual machine 110A, 110B.
  • As shown representatively in FIG. 1, the attached storage volumes 170 may then be attached to the target virtual machines 110A, 110B. The attached storage volumes 170 are shown within the target virtual machines 110 to emphasize the attachment of the selected storage volumes 170, though it will be appreciated that the selected storage volume 170 may not actually be transferred into the target virtual machines 170. Typically, the disk blocks in the storage volume would only be accessed by the hypervisor and transferred into the virtual machine upon a disk read event from the virtual machine.
  • As will be discussed in more detail at an appropriate point hereinafter, the system 100 is configured to make the application storage volume 160, including one or more applications 162 stored thereon, available to a plurality of virtual machines (represented schematically as the virtual machines 110A, 110B) concurrently.
  • In at least one example, the hypervisor 115 abstracts the physical hardware of the host computing device so that the virtual machine sees virtual hardware regardless of what the underlying hardware actually is. The application storage volume 160 is mounted by the hypervisor 115 to thereby allow the virtual machines 110A, 110B to access the application 162 on the application storage volume 160 through the hypervisor 115. For example, if the storage volume 160 is concurrently attached by hypervisor 115 to virtual machines 110A, 110B the storage volume 160 would appear as a locally attached hard disk (such as a SCSI disk) within the virtual machine. In at least one example, the application 162 may be stored on the application storage volume 160 as a read only volume. As a result, the virtual machines 110A, 110B may be able to only access and execute the application 162 rather than modify the application. In at least one example, the application storage volume 160 may be attached as a non-persistent writable volume to enable it to be concurrently shared. In this way, the application or its data may be modified by virtual machine 110A, 110B but the changes will be discarded once the application storage volume 160 is detached from the virtual machine.
  • Such configurations may allow the application 162 to be accessed by the virtual machines 110A, 110B concurrently. For example, as illustrated in FIG. 1, the hypervisor 115 can attach the application 162 to one or more of the virtual machines 110A, 110B concurrently as desired. The attachment of the application 162 to the virtual machine may be performed in any desired manner.
  • In one embodiment, the application storage volume 160 can be statically attached to one of the virtual machines 110A, 110B, in which case it will remain permanently attached to the virtual machine 110A, 110B. In another embodiment, the VM agents 120A, 120B running in the virtual machines 110A, 110B can dynamically request the VM manager 130 to request the hypervisor 115 to attach the application storage volume 160 on demand. This may be desirable, for example, to enable an IT administrator to track software license compliance by tracking how many virtual machines are concurrently using an application. Such a configuration may allow the system to load applications and data into the target virtual machine automatically or dynamically as desired. Similarly, a user or administrator could directly interact with the VM manager 130 to request an application storage volume be attached to or detached from a plurality of virtual machines on demand. To this end, the VM manager 130 could expose a management interface for users and administrators to interact with.
  • FIG. 2 is a flowchart illustrating a method 200 for loading applications and data into a virtual machine. As shown in FIG. 2, the method begins at step 210 with a VM agent responding to the detection of an attach-triggering event. Based on the detection of the attach-triggering event, at step 220 volumes to be attached to the target virtual machine are identified. Thereafter, at step 230 the selected volumes are dynamically attached to the target virtual machine. Attaching the volume dynamically may allow for sharing an application across multiple virtual machines simultaneously.
  • FIG. 3 is a flowchart illustrating a method 300 for sharing an application across multiple virtual machines simultaneously. As shown in FIG. 3, the method begins at step 310 by placing an application on an application storage volume. In at least one example, placing the application on the application storage volume includes setting the application storage volume state to read only.
  • Thereafter, at step 320 a hypervisor associated with a plurality of virtual machines attaches the application storage volume to each virtual machine concurrently. In particular, the application storage volume, including applications stored thereon, is attached to selected virtual machines. This attachment may be static or dynamic as desired. Once the application storage volume has been attached to the virtual machine by the hypervisor, the operating system within the virtual machine can thereby mount the file system contained on the application storage volume and access its contents.
  • With the file system containing the applications thus mounted within the virtual machine, the method at step 330 includes making the applications available to a plurality of virtual machines concurrently. Within each virtual machine, the VM agent (in cooperation with the volume detector described later) can detect the presence of the new applications and automatically start the applications contained within the application storage volume or notify the user that new applications are available.
  • FIG. 4 illustrates a system 400 that includes storage repository 410, a plurality of virtual machines 420A-420C executed by a hypervisor 430, and a virtual machine manager (VM manager) 440. In the illustrated example, VM agents 422A-422C running inside the virtual machines 420 contacts the VM manager 440 to request the hypervisor 430 to dynamically attach one or more of the storage volumes 412-416 or applications 419A-419D within an application repository 418 when certain conditions are met. The VM agents 422A-422C, in various embodiments, could be a Windows service, a Unix daemon, or a script.
  • The VM agents 422A-422C are configured to detect when a specific event happens (an “attach-triggering event”) and respond to it by informing the VM manager. An attach-triggering event could be that the operating system in the associated virtual machine 420A-420C is booting (“VM startup”), user has logged into the operating system of the VM (“user logon”), or some other identifiable event. For ease of reference, VM agent 422A running within virtual machine 420A will be described. It will be appreciated that the discussion of the virtual machine 420A and VM agent 422A may be equally applicable to the other virtual machines 420B-420C and VM agents 422B-422C.
  • Further, the VM manager 440 may be a part of the VM agent 422A itself. In other examples, the VM manager 440 may reside on a separate physical computer or a separate virtual machine that the VM agent 422A communicates with over a network.
  • The VM manager 440 may be responsible for deciding which of storage volumes 412-416 and/or application volumes 419A-419D should be attached based on the certain criterion. If the attach-triggering event is a VM startup, the VM manager 440 may look for storage volumes that should be applied based on the virtual machine. If the attach-triggering event is a user logon, the VM manager 440 may look for storage volumes that should be applied based on the user.
  • When the attach-triggering event is a VM startup, the VM manager 440 will look for a writable storage volume associated with the virtual machine 422A (computer volume 412) and any of the application volumes 419A-419D that should be dynamically provided to the virtual machine 422A from the application repository 418. The sharing of the applications 419A-419D across the virtual machines 420A-420C will be discussed in more detail at an appropriate point hereinafter. The VM manager 440 can store this information in its internal memory, in a database (such as Configuration Database 448) or in a directory (such as “Active Directory”).
  • When the attach-triggering event is a user logon, the VM manager 440 will look for a writable storage volume associated with the user (user volume 414) and any application volumes, such as the application volumes 419A-419D in the application repository 418. The user volume 414 may include user-installed applications, Windows profile (home directory), preferences and settings, files, and registry keys (inside of a registry hive). Such a configuration may help the system 400 provide a persistent virtual environment for each user in an efficient manner.
  • The storage volumes 412-416 and application volumes 419A-419D to be attached to the virtual machine 420A can be selected based on individual identity (a user volume belonging to a particular user) or based on a group (if the virtual machine 422A is a member of a particular group of computers, or if the user is a member of a group of users). For example, if all users in the engineering group need a particular application, such as Microsoft Visual Studio, when a user who is a member of the engineering group logs into the virtual machine 420A, the VM agent 422A will inform the VM manager 440 of the user logon event.
  • The VM manager 440 will then check for the user volume 414 belonging to the user, any application volumes 419A-419D belonging to the user, and any application volumes 419A-419D belonging to the groups the user belongs to. Upon the system 400 detecting the attach-triggering event, the VM agent 422A communicates with the VM manager 440. In at least one example, the VM manager 440 is responsible for deciding which of the appropriate storage volumes 412-418 and/or applications 419A-419D should be attached to the virtual machine 420A.
  • In particular, attached volumes described above may contain a file system with files and registry keys. The registry keys can be stored in a file or directory located on the attached volume. In one embodiment, this file format can be a one or more registry hive files (just as the HKEY_CURRENT_USER registry hive is a file named ntuser.dat located within the user's profile). In another embodiment, the registry keys could be represented in a database or a proprietary format describing registry metadata.
  • In one embodiment, VM agents 422A-422C shown in FIG. 4, can detect when the volume has been attached and enumerate the registry keys on the volume (whether represented as a hive or a set of directories and files on the volume). The VM agent will look for known load points, such as HKEY_LOCAL_MACHINE\CurrentControlSet\Services, to locate programs, services, and drivers to be started. This process of locating programs, services, and drivers to be launched by the VM agents mimics what the operating system would normally do upon starting up. Thus, when an attach-triggering event occurs and the applicable storage volumes are attached, all of the programs, services, and drivers configured located on those volumes will be made available and start as if they were installed traditionally within the virtual machine. In one embodiment, a driver (a mini-filter driver or a file system filter driver, familiar to those skilled in the art) will detect attempts to write to non-persistent file systems (such as the C:\drive) and will redirect the access to an attached, writable volume dedicated to the user or virtual machine.
  • Once the VM manager 440 has selected the relevant set of storage volumes based on the attach-triggering event, the VM manager 440 directly or indirectly contacts the hypervisor 430 and requests for the storage volumes 412-416 and/or application volumes 419A-419D to be attached to the virtual machine 420A. For example, the VM manager 440 could directly request the storage volumes 412-416 and/or application volumes 419A-419D to be attached to the virtual machine 420A by connecting to the hypervisor 430 (such as VMware ESX server). The VM manager 440 could indirectly request the storage volumes 412-416 and/or the application volumes 419A-419D to be attached to the virtual machine 420A by connecting to a virtual datacenter manager 450 responsible for managing several hypervisors (such as a VMware vCenter server). Further, application brokers may be utilized with the system to help control and/or optimize the management of data by the system 400, as will be discussed at appropriate locations hereinafter.
  • In some examples, the computer volumes 412 and user volumes 414 are types of writable storage. In such examples, the computer volumes 412 and user volumes 414 may be specific to each user or virtual machine. In at least one example, the application volumes 419A-419D in the application repository may be read-only and can be shared by multiple virtual machines concurrently. In another example, these application volumes could be writable but non-persistent, such that the changes are discarded once the volume is detached from the virtual machine. Exemplary sharing of the application volumes 419A-419D will now be discussed in more detail.
  • As previously discussed, to dynamically attach one of the application volumes 419A-419D to the virtual machines 420A-420C, the virtual machine agents 422A-422C can be configured to either (1) directly request the hypervisor 430 to request selected application volumes 419A-419D to be dynamically attached or (2) indirectly request the application volumes 419A-419D to be attached by first communicating with VM manager 440. Communicating with the VM manager 440 may reduce the exposure of the credentials of the hypervisor 430 within each virtual machine.
  • To enable better distribution of resources, an application broker 460 can be consulted which will choose the best location to source the application volumes 419A-419D from when there is more than one copy of the application volumes available. In one example, the application broker could be responsible for communicating the hypervisor to directly attach the application volume selected. In another example, the application broker merely points to the best location to source the application storage volume from and leaves the responsibility to the VM manager to actually instruct the hypervisor to attach the relevant application storage volume.
  • To provide redundancy and enable a large number of virtual machines to share an application, the application can be placed into multiple, redundant storage volumes. For example, the application could be located on two different storage volumes within two different data stores within a data center. The application broker 460 may be operatively associated with the application repository 418 to allow the application broker 460 to track availability of and latency to the different application storage volumes containing a selected application.
  • When the the application broker 460 is contacted to request an application, the application broker 460 can dynamically decide which application volumes 419A-419D to attach based on the aforementioned latency and availability checks. In other embodiments, numerous strategies could be used by the application broker 460 to select an application volume such as round-robin, least recently used storage application volume, lowest latency, etc.
  • In at least one example, each of the virtual machines 420A-420C may include a volume detector 424A-424C respectively. The volume detector 424A-424C can be configured to detect when a new storage volume has been attached to the virtual machine 420A-420C. In one embodiment, this can be a file system filter driver. In another embodiment, this may be a file system mini-filter driver. In another embodiment, this can be a Windows service configured to detect when new storage devices have been attached. Once a new storage volume has been detected, a volume overlay software agent will be invoked (the volume overlay agents 426A-426C). The volume overlay agents 426A-426C may be part of the volume detectors 424A-424C or may be a separate driver as shown. Each of the volume overlay agents 426A-426C is responsible for exposing the data and applications contained in the storage repository 410 and making it available to the corresponding virtual machine 420A-420C.
  • The volume overlay agents 426A-426C may accomplish this by overlaying the content (such as files and registry keys) on top of the existing virtual machines 420A-420C so that the content can be seamlessly integrated into the virtual machine environments. In addition, if one or more applications contained in a storage volume are meant to start automatically, then the VM agents 422A-422C can enumerate the contents of the volume and automatically start the relevant services or drivers. For example, the VM agent can enumerate all Start registry values to look for services contained in the KEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services subtree that should be automatically started and invoke the relevant APIs (such as ZwLoadDriver and Start Service).
  • The VM agents 422A-422C are also configured to respond to detection of a specific triggering event (“detach-triggering event”). Detach-triggering events include a virtual machine being powered off or a user logging off. When a detach-triggering event occurs, the VM agent contacts the VM manager to report the detach-triggering event. In the same manner outlined in the aforementioned process of handling the attach-triggering event, the VM manager may then directly or indirectly request the hypervisor 430 to detach the storage volume from the corresponding virtual machine 420A-420C. To this point, attachment of the application storage volumes has been discussed generally. In at least one example, once a user logs into a virtual machine, storage will be dynamically attached to the virtual machine without the need to reboot the virtual machine. Once the storage is attached to the virtual machine, the storage will be directly accessible from within the virtual machine. This enables a non-persistent virtual machine to function as if it is a persistent virtual machine.
  • The storage dynamically attached to the virtual machine utilized by this invention can be in any form supported by the hypervisor and operating system of the virtual machine. The storage dynamically attached to the virtual machine may contain multiple partitions, volumes, and file systems. Storage concepts such as partitions, volumes, and file systems are well-known to skilled artisans and outside the scope of this invention.
  • In one embodiment, the storage dynamically attached to the virtual machine can be attached through a network (using protocols such as iSCSI or Fibre Channel which reference storage by LUNs, or logical unit numbers). In another embodiment, the storage dynamically attached to the virtual machine is directly attached from physical volumes (raw device mapping) such as a hard disk and hard disk partitions and the hypervisor with pass through access from the virtual machine directly to the hardware. In another embodiment, the storage dynamically attached to the virtual machine can be a virtual device represented by a file (an ISO representing a virtual CD-ROM or a virtual hard disk file such as the VMDK and VHD file formats which represent a disk).
  • The storage dynamically attached to the virtual machine does not need to be contained within a single physical device or single virtual device represented by a file. The storage may be in the form of different virtual hard disk files or physical devices attached simultaneously which represent “physical volumes” within the virtual machine. These physical volumes will be composed of logical volumes. This approach, known as storage virtualization, allows logical volumes to be abstracted from the underlying physical storage. A logical volume (itself containing a file system) spread out across multiple physical volumes can lead to improved redundancy and performance where logical volumes. Technology to provide this storage virtualization, such as Redundant Array of Independent Disks (RAID for short), logical volumes, and physical volumes, are well-known to skilled artisans and outside the scope of this invention.
  • Hereafter, “volume” and “volumes” will be used to refer to logical storage volumes visible within the virtual machine including (1) the volume containing the operating system (typically the C: drive for the Windows® operating system) and (2) any dynamically attached storage previously described above.
  • Whenever the user logs off, the volumes associated with the user are detached. When the user logs into a different virtual machine, the volumes associated with the user are attached to the new virtual machine. As such, the user's writable volume containing the user's data and user-installed applications and any application volumes containing applications assigned to the user will remain available to the user regardless of which virtual machine the user is using.
  • In another embodiment, if a writable volume needs to be used simultaneously from two different virtual machines (for example, because the user logs in to two separate virtual machines), a new volume can be created that is a differential disk or a delta disk of the writable volume. If a user logs in to two separate virtual machines, each would receive a separate copy of the user's writable volume that can be written to. Only the modifications go into the delta disk. Once the user logs off the virtual machine, the data in the delta disk would be reintegrated into the original volume. If the changes made by the user on the two different virtual machines conflict (such that the changes to the two separate linked clones modify the same data), a software policy can determine the appropriate way to resolve the conflict. A software policy for conflict resolution could be, for example, to favor newer changes such that the delta disk with the most recent modification will pre-empt any older, overlapping modification from a different delta disk.
  • This invention thus enables applications, services, and drivers to be installed on separate volumes that are dynamically attached after a user has logged in or after a virtual machine has booted up as if the applications, services, or drivers were part of the original virtual machine. This enables the virtual machine to be a minimal virtual machine which only needs to have the VM agents to support dynamically attached volumes. All other programs can be made available at run-time (after a user logs in) depending on which user logs in or which group the user logs into. While an engineer might need a different set of applications than an accountant, they can share the same set of pooled, non-persistent virtual machines.
  • Because all of these volumes are centrally managed in the data center. The IT department can update software located in the volumes. IT staff can also ensure license compliance (by determining how many users are utilizing a given volume containing the licensed software). In virtual machine environments, storage volumes within the virtual machines contain data items that need to be accessed. Unfortunately, accessing the underlying contents of a storage volume can be very resource intensive, reducing the performance of a virtual machine and other operations within a virtual machine environment.
  • The above description and associated figures teach the best mode of the invention. The following claims specify the scope of the invention. Note that some aspects of the best mode may not fall within the scope of the invention as specified by the claims. Those skilled in the art will appreciate that the features described above can be combined in various ways to form multiple variations of the invention. As a result, the invention is not limited to the specific embodiments described above, but only by the following claims and their equivalents.

Claims (20)

1. A method of operating a data management system, comprising:
a virtual machine agent running within a virtual machine responding to an attach-triggering event;
determining selected storage volumes to be attached to the virtual machine based on a request generated by the virtual agent in response to the attach-triggering event; and
dynamically attaching the selected storage volumes to the virtual machine.
2. The method of claim 1, further comprising mounting the selected storage volumes with a hypervisor, the hypervisor being configured to operate a plurality of virtual machines, and making at least one application stored on the selected storage volumes available to a plurality of virtual machines concurrently via the hypervisor.
3. The method of claim 2, wherein a virtual machine manager determines the selected storage volumes to be attached to the virtual machine based on the attach-triggering event and wherein the step of dynamically attaching the selected storage volumes to the virtual machine includes the virtual machine manager instructing the hypervisor which storage volumes to attach to the virtual machine.
4. The method of claim 2, wherein a virtual machine manager determines the selected storage volumes to be attached to the virtual machine based on the attach-triggering event and wherein the step of dynamically attaching the selected storage volumes to the virtual machine includes the virtual machine manager instructing a datacenter manager responsible for managing a plurality of hypervisors to cause one of the plurality of hypervisors to attach the a selected set of storage volumes to the virtual machine.
5. The method of claim 2, wherein the attach-triggering event is a user logon or a virtual machine startup event.
6. The method of claim 5, wherein the selected storage volumes includes data specific to a user associated with the user logon event or specific to the virtual machine associated with a virtual machine startup event.
7. The method of claim 2, wherein the selected storage volume includes applications in a read-only state associated with a user identified by the user logon event or associated with a virtual machine identified by the virtual machine startup event.
8. The method of claim 7, further comprising tracking instances of each application running on the plurality of virtual machines.
9. The method of claim 8, comprising an application broker configured to select a location from which to source an application storage volume when the application storage volume is available in multiple locations.
10. The method of claim 1, further comprising detecting available storage volumes.
11. A data management system, comprising:
a plurality of storage volumes;
a hypervisor configured to operate a plurality of virtual machines having secondary storage volumes, wherein the virtual machines include virtual machine agent running which start based on an attach-triggering event; and
a virtual machine manager configured to identify selected storage volumes to be attached to the plurality of virtual machines based on a request generated by the virtual agent in response to the attach-triggering event, wherein the hypervisor is configured to dynamically attach the storage volumes to the secondary storage volumes associated with the plurality of virtual machines.
12. The system of claim 11, wherein the hypervisor is configured to mount the storage volumes and make at least one application stored on the storage volumes available to a plurality of virtual machines concurrently via the hypervisor.
13. The system of claim 11, further comprising a datacenter manager wherein the virtual machine manager instructs a datacenter manager responsible for managing a plurality of hypervisors to cause one of the plurality of hypervisors to attach the application to the virtual machine.
14. The system of claim 11, wherein the attach-triggering event is a user logon event or a virtual machine startup event.
15. The system of claim 14, wherein the selected storage volumes includes data specific to a user associated with the user logon event or specific to a virtual machine associated with the virtual machine startup event.
16. The system of claim 11, wherein the selected storage volume includes applications in a read-only state associated with a user identified by the user logon event or associated with a virtual machine identified by the virtual machine startup event.
17. The system of claim 16, further comprising a license tracker configured to track instances of each application running on the plurality of virtual machines.
18. A computer readable medium having program instruction stored thereon for operating a data management system, wherein the program instructions, when executed by the data management system, direct the data management system to:
a virtual machine agent running within a virtual machine responding to an attach-triggering event;
determine selected storage volumes to be attached to the virtual machine based on a request generated by the virtual agent in response to the attach-triggering event; and
dynamically attach the selected storage volumes to the virtual machine.
19. The computer readable medium of claim 18, further having program instructions stored thereon for mounting the selected storage volumes with a hypervisor, the hypervisor being configured to operate a plurality of virtual machines, and making at least one application stored on the selected storage volumes available to a plurality of virtual machines concurrently via the hypervisor.
20. The computer readable medium of claim 19, wherein a virtual machine manager determines the selected storage volumes to be attached to the virtual machine based on the attach-triggering event and wherein the step of dynamically attaching the selected storage volumes to the virtual machine includes the virtual machine manager instructing the hypervisor which storage volumes to attach to the virtual machine.
US13/247,693 2010-12-30 2011-09-28 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes Abandoned US20120174096A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US13/247,693 US20120174096A1 (en) 2010-12-30 2011-09-28 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes
US14/458,586 US9639385B2 (en) 2010-12-30 2014-08-13 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US201061428690P 2010-12-30 2010-12-30
US201161475832P 2011-04-15 2011-04-15
US201161475881P 2011-04-15 2011-04-15
US13/247,693 US20120174096A1 (en) 2010-12-30 2011-09-28 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US14/458,586 Continuation US9639385B2 (en) 2010-12-30 2014-08-13 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes

Publications (1)

Publication Number Publication Date
US20120174096A1 true US20120174096A1 (en) 2012-07-05

Family

ID=46381983

Family Applications (2)

Application Number Title Priority Date Filing Date
US13/247,693 Abandoned US20120174096A1 (en) 2010-12-30 2011-09-28 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes
US14/458,586 Active 2031-12-21 US9639385B2 (en) 2010-12-30 2014-08-13 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes

Family Applications After (1)

Application Number Title Priority Date Filing Date
US14/458,586 Active 2031-12-21 US9639385B2 (en) 2010-12-30 2014-08-13 Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes

Country Status (1)

Country Link
US (2) US20120174096A1 (en)

Cited By (35)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120246215A1 (en) * 2011-03-27 2012-09-27 Michael Gopshtein Identying users of remote sessions
US20130086585A1 (en) * 2011-09-30 2013-04-04 International Business Machines Corporation Managing the Persistent Data of a Pre-Installed Application in an Elastic Virtual Machine Instance
US20130132953A1 (en) * 2011-11-21 2013-05-23 Institute For Information Industry Method and System for Providing Application by Virtual Machine and Computer-Readable Storage Medium to Execute the Method
US20130152084A1 (en) * 2011-12-09 2013-06-13 International Business Machines Corporation Controlling Usage of Virtual Disks Before Their Attachment to Virtual Machines
WO2014018644A2 (en) 2012-07-24 2014-01-30 Cloudvolumes Inc. Systems and methods for operating an application distribution system
US20140082131A1 (en) * 2012-09-14 2014-03-20 Ca, Inc. Automatically configured management service payloads for cloud it services delivery
US20140089922A1 (en) * 2012-09-25 2014-03-27 International Business Machines Corporation Managing a virtual computer resource
US20140201725A1 (en) * 2013-01-14 2014-07-17 Vmware, Inc. Techniques for performing virtual machine software upgrades using virtual disk swapping
US20150012920A1 (en) * 2013-07-02 2015-01-08 International Business Machines Corporation Managing Virtual Machine Policy Compliance
US9202046B2 (en) 2014-03-03 2015-12-01 Bitdefender IPR Management Ltd. Systems and methods for executing arbitrary applications in secure environments
US20150378768A1 (en) * 2014-06-30 2015-12-31 Vmware, Inc. Location management in a volume action service
US9323565B2 (en) 2013-12-20 2016-04-26 Vmware, Inc. Provisioning customized virtual machines without rebooting
US9477507B2 (en) 2013-12-20 2016-10-25 Vmware, Inc. State customization of forked virtual machines
US9513949B2 (en) * 2014-08-23 2016-12-06 Vmware, Inc. Machine identity persistence for users of non-persistent virtual desktops
US9590872B1 (en) 2013-03-14 2017-03-07 Ca, Inc. Automated cloud IT services delivery solution model
US9678769B1 (en) * 2013-06-12 2017-06-13 Amazon Technologies, Inc. Offline volume modifications
US9696983B2 (en) 2014-04-25 2017-07-04 Vmware, Inc. Dynamic updating of operating systems and applications using volume attachment
US9754303B1 (en) 2013-10-03 2017-09-05 Ca, Inc. Service offering templates for user interface customization in CITS delivery containers
WO2017205520A1 (en) 2016-05-24 2017-11-30 FSLogix, Inc. Systems and methods for accessing remote files
US9971621B1 (en) * 2015-02-02 2018-05-15 Amazon Technologies, Inc. Hotpooling virtual machines
US10019277B2 (en) * 2015-06-04 2018-07-10 Vmware, Inc. Triggering application attachment based on state changes of virtual machines
US10120703B2 (en) 2015-03-20 2018-11-06 Amazon Technologies, Inc. Executing commands within virtual machine instances
US10324744B2 (en) 2015-06-04 2019-06-18 Vmware, Inc. Triggering application attachment based on service login
US10409625B1 (en) * 2013-09-17 2019-09-10 Amazon Technologies, Inc. Version management for hosted computing workspaces
US20190327159A1 (en) * 2018-04-20 2019-10-24 Nutanix, Inc. Systems and methods for identifying and displaying logon duration metrics
US10484332B2 (en) * 2016-12-02 2019-11-19 Vmware, Inc. Application based network traffic management
US10635318B2 (en) * 2017-12-27 2020-04-28 Intel Corporation Logical storage driver
US10719342B2 (en) 2015-11-25 2020-07-21 International Business Machines Corporation Provisioning based on workload displacement
US10949306B2 (en) * 2018-01-17 2021-03-16 Arista Networks, Inc. System and method of a cloud service provider virtual machine recovery
US10972355B1 (en) * 2018-04-04 2021-04-06 Amazon Technologies, Inc. Managing local storage devices as a service
US10977063B2 (en) 2013-12-20 2021-04-13 Vmware, Inc. Elastic compute fabric using virtual machine templates
US11126476B2 (en) 2013-09-10 2021-09-21 Vmware, Inc. Selectively filtering applications from an application volume
US11709799B2 (en) 2015-08-29 2023-07-25 Vmware, Inc. Content or file based application virtualization using a cache
US11748006B1 (en) 2018-05-31 2023-09-05 Pure Storage, Inc. Mount path management for virtual storage volumes in a containerized storage environment
US12105681B2 (en) 2016-06-22 2024-10-01 Omnissa, Llc Automatic document handling with on-demand application mounting

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10091055B2 (en) * 2015-02-13 2018-10-02 Amazon Technologies, Inc. Configuration service for configuring instances
US10740038B2 (en) * 2017-08-21 2020-08-11 Vmware, Inc. Virtual application delivery using synthetic block devices
US10747599B2 (en) 2018-05-21 2020-08-18 Red Hat, Inc. Secure backwards compatible orchestration of isolated guests

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8364802B1 (en) * 2008-09-23 2013-01-29 Gogrid, LLC System and method for monitoring a grid of hosting resources in order to facilitate management of the hosting resources
US20130290960A1 (en) * 2008-05-02 2013-10-31 Skytap Multitenant hosted virtual machine infrastructure

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8555274B1 (en) * 2006-03-31 2013-10-08 Vmware, Inc. Virtualized desktop allocation system using virtual infrastructure
US8677351B2 (en) 2007-03-29 2014-03-18 Vmware, Inc. System and method for delivering software update to guest software on virtual machines through a backdoor software communication pipe thereof
US20110061046A1 (en) 2008-12-18 2011-03-10 Virtual Computer, Inc. Installing Software Applications in a Layered Virtual Workspace
US9805041B2 (en) 2009-05-04 2017-10-31 Open Invention Network, Llc Policy based layered filesystem management
US8140735B2 (en) * 2010-02-17 2012-03-20 Novell, Inc. Techniques for dynamic disk personalization
US20120054742A1 (en) 2010-09-01 2012-03-01 Microsoft Corporation State Separation Of User Data From Operating System In A Pooled VM Environment

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130290960A1 (en) * 2008-05-02 2013-10-31 Skytap Multitenant hosted virtual machine infrastructure
US8364802B1 (en) * 2008-09-23 2013-01-29 Gogrid, LLC System and method for monitoring a grid of hosting resources in order to facilitate management of the hosting resources

Cited By (63)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8713088B2 (en) * 2011-03-27 2014-04-29 Hewlett-Packard Development Company, L.P. Identifying users of remote sessions
US20120246215A1 (en) * 2011-03-27 2012-09-27 Michael Gopshtein Identying users of remote sessions
US20130086585A1 (en) * 2011-09-30 2013-04-04 International Business Machines Corporation Managing the Persistent Data of a Pre-Installed Application in an Elastic Virtual Machine Instance
US9946578B2 (en) * 2011-09-30 2018-04-17 International Business Machines Corporation Managing the persistent data of a pre-installed application in an elastic virtual machine instance
US20130132953A1 (en) * 2011-11-21 2013-05-23 Institute For Information Industry Method and System for Providing Application by Virtual Machine and Computer-Readable Storage Medium to Execute the Method
US20130152084A1 (en) * 2011-12-09 2013-06-13 International Business Machines Corporation Controlling Usage of Virtual Disks Before Their Attachment to Virtual Machines
US10635482B2 (en) 2011-12-09 2020-04-28 International Business Machines Corporation Controlling usage of virtual disks before their attachment to virtual machines
US10282221B2 (en) * 2011-12-09 2019-05-07 International Business Machines Corporation Controlling usage of virtual disks before their attachment to virtual machines
WO2014018644A2 (en) 2012-07-24 2014-01-30 Cloudvolumes Inc. Systems and methods for operating an application distribution system
WO2014018644A3 (en) * 2012-07-24 2014-04-03 Cloudvolumes Inc. Disambiguating user intent in conversational interaction
JP2015523665A (en) * 2012-07-24 2015-08-13 クラウドボリュームズ インコーポレイテッドCloudvolumesinc. System and method for operating an application distribution system
AU2013295867B2 (en) * 2012-07-24 2015-11-26 VMware LLC Disambiguating user intent in conversational interaction
US20140082131A1 (en) * 2012-09-14 2014-03-20 Ca, Inc. Automatically configured management service payloads for cloud it services delivery
US9311161B2 (en) * 2012-09-14 2016-04-12 Ca, Inc. Automatically configured management service payloads for cloud IT services delivery
US10387211B2 (en) 2012-09-25 2019-08-20 International Business Machines Corporation Managing a virtual computer resource
US9952910B2 (en) 2012-09-25 2018-04-24 International Business Machines Corporation Managing a virtual computer resource
US20140089922A1 (en) * 2012-09-25 2014-03-27 International Business Machines Corporation Managing a virtual computer resource
US9292325B2 (en) * 2012-09-25 2016-03-22 International Business Machines Corporation Managing a virtual computer resource
US20140201725A1 (en) * 2013-01-14 2014-07-17 Vmware, Inc. Techniques for performing virtual machine software upgrades using virtual disk swapping
US20150339149A1 (en) * 2013-01-14 2015-11-26 Vmware, Inc. Techniques for performing virtual machine software upgrades using virtual disk swapping
US9471365B2 (en) * 2013-01-14 2016-10-18 Vmware, Inc. Techniques for performing virtual machine software upgrades using virtual disk swapping
US9110757B2 (en) * 2013-01-14 2015-08-18 Vmware, Inc. Techniques for performing virtual machine software upgrades using virtual disk swapping
US9590872B1 (en) 2013-03-14 2017-03-07 Ca, Inc. Automated cloud IT services delivery solution model
US10437617B2 (en) 2013-06-12 2019-10-08 Amazon Technologies, Inc. Offline volume modifications
US9678769B1 (en) * 2013-06-12 2017-06-13 Amazon Technologies, Inc. Offline volume modifications
US20150012920A1 (en) * 2013-07-02 2015-01-08 International Business Machines Corporation Managing Virtual Machine Policy Compliance
US10108444B2 (en) 2013-07-02 2018-10-23 International Business Machines Corporation Managing virtual machine policy compliance
US9697025B2 (en) * 2013-07-02 2017-07-04 International Business Machines Corporation Managing virtual machine policy compliance
US11768719B2 (en) * 2013-09-10 2023-09-26 Vmware, Inc. Selectively filtering applications from an application volume
US20220004446A1 (en) * 2013-09-10 2022-01-06 Vmware, Inc. Selectively filtering applications from an application volume
US11126476B2 (en) 2013-09-10 2021-09-21 Vmware, Inc. Selectively filtering applications from an application volume
US10409625B1 (en) * 2013-09-17 2019-09-10 Amazon Technologies, Inc. Version management for hosted computing workspaces
US9754303B1 (en) 2013-10-03 2017-09-05 Ca, Inc. Service offering templates for user interface customization in CITS delivery containers
US9323565B2 (en) 2013-12-20 2016-04-26 Vmware, Inc. Provisioning customized virtual machines without rebooting
US9477507B2 (en) 2013-12-20 2016-10-25 Vmware, Inc. State customization of forked virtual machines
US10977063B2 (en) 2013-12-20 2021-04-13 Vmware, Inc. Elastic compute fabric using virtual machine templates
US10203978B2 (en) 2013-12-20 2019-02-12 Vmware Inc. Provisioning customized virtual machines without rebooting
US9202046B2 (en) 2014-03-03 2015-12-01 Bitdefender IPR Management Ltd. Systems and methods for executing arbitrary applications in secure environments
US9696983B2 (en) 2014-04-25 2017-07-04 Vmware, Inc. Dynamic updating of operating systems and applications using volume attachment
US20150378768A1 (en) * 2014-06-30 2015-12-31 Vmware, Inc. Location management in a volume action service
US11210120B2 (en) * 2014-06-30 2021-12-28 Vmware, Inc. Location management in a volume action service
US9513949B2 (en) * 2014-08-23 2016-12-06 Vmware, Inc. Machine identity persistence for users of non-persistent virtual desktops
US9619268B2 (en) 2014-08-23 2017-04-11 Vmware, Inc. Rapid suspend/resume for virtual machines via resource sharing
US9971621B1 (en) * 2015-02-02 2018-05-15 Amazon Technologies, Inc. Hotpooling virtual machines
US10768955B1 (en) 2015-03-20 2020-09-08 Amazon Technologies, Inc. Executing commands within virtual machine instances
US10120703B2 (en) 2015-03-20 2018-11-06 Amazon Technologies, Inc. Executing commands within virtual machine instances
US10019277B2 (en) * 2015-06-04 2018-07-10 Vmware, Inc. Triggering application attachment based on state changes of virtual machines
US10324744B2 (en) 2015-06-04 2019-06-18 Vmware, Inc. Triggering application attachment based on service login
US11709799B2 (en) 2015-08-29 2023-07-25 Vmware, Inc. Content or file based application virtualization using a cache
US10725805B2 (en) 2015-11-25 2020-07-28 International Business Machines Corporation Provisioning based on workload displacement
US10719342B2 (en) 2015-11-25 2020-07-21 International Business Machines Corporation Provisioning based on workload displacement
WO2017205520A1 (en) 2016-05-24 2017-11-30 FSLogix, Inc. Systems and methods for accessing remote files
US11157461B2 (en) 2016-05-24 2021-10-26 Microsoft Technology Licensing, Llc Systems and methods for accessing remote files
EP3465420A4 (en) * 2016-05-24 2020-01-15 FSLogix Inc. Systems and methods for accessing remote files
CN109478143A (en) * 2016-05-24 2019-03-15 弗斯罗吉克斯公司 System and method for accessing telefile
US12105681B2 (en) 2016-06-22 2024-10-01 Omnissa, Llc Automatic document handling with on-demand application mounting
US10484332B2 (en) * 2016-12-02 2019-11-19 Vmware, Inc. Application based network traffic management
US11394689B2 (en) * 2016-12-02 2022-07-19 Vmware, Inc. Application based network traffic management
US10635318B2 (en) * 2017-12-27 2020-04-28 Intel Corporation Logical storage driver
US10949306B2 (en) * 2018-01-17 2021-03-16 Arista Networks, Inc. System and method of a cloud service provider virtual machine recovery
US10972355B1 (en) * 2018-04-04 2021-04-06 Amazon Technologies, Inc. Managing local storage devices as a service
US20190327159A1 (en) * 2018-04-20 2019-10-24 Nutanix, Inc. Systems and methods for identifying and displaying logon duration metrics
US11748006B1 (en) 2018-05-31 2023-09-05 Pure Storage, Inc. Mount path management for virtual storage volumes in a containerized storage environment

Also Published As

Publication number Publication date
US9639385B2 (en) 2017-05-02
US20140351815A1 (en) 2014-11-27

Similar Documents

Publication Publication Date Title
US9639385B2 (en) Systems and methods to load applications and application data into a virtual machine using hypervisor-attached volumes
US10606628B2 (en) Systems and methods for modifying an operating system for a virtual machine
US10261800B2 (en) Intelligent boot device selection and recovery
US8694746B2 (en) Loose synchronization of virtual disks
US9384060B2 (en) Dynamic allocation and assignment of virtual functions within fabric
US9547506B2 (en) Synthetic device for installation source media
US9632813B2 (en) High availability for virtual machines in nested hypervisors
US8521686B2 (en) Concurrency control in a file system shared by application hosts
US11995449B2 (en) Layered composite boot device and file system for operating system booting in file system virtualization environments
US9804877B2 (en) Reset of single root PCI manager and physical functions within a fabric
US7143281B2 (en) Method and apparatus for automatically changing kernel tuning parameters
JP6014257B2 (en) System and method for operating an application distribution system
US10296318B2 (en) Offline tools upgrade for virtual machines
US20160077847A1 (en) Synchronization of physical functions and virtual functions within a fabric
US11792278B2 (en) Resolving conflicts of application runtime dependencies
US10365907B2 (en) Offline tools installation for virtual machines

Legal Events

Date Code Title Description
AS Assignment

Owner name: SNAPVOLUMES, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CONOVER, MATTHEW;REEL/FRAME:027093/0024

Effective date: 20111014

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION

AS Assignment

Owner name: CLOUDVOLUMES, INC., CALIFORNIA

Free format text: CHANGE OF NAME;ASSIGNOR:SNAPVOLUMES, INC.;REEL/FRAME:033577/0692

Effective date: 20130204