CREATING TEMPLATES OF OFFLINE RESOURCES
Implementations of the present invention allow software resources to be duplicated efficiently and effectively while offline. In one implementation, a preparation program receives an identification of a software resource, such as a virtual machine installed on a different volume, an offline operating system, or an application program. The preparation program also receives an indication of customized indicia that are to be removed from the software resource. These indicia can include personalized information as well as the level of software updates, security settings, user settings or the like. Upon execution, the preparation program redirects the function calls of the preparation program to the software resource at the different volume (or even the same volume) while the software resource is not running. The preparation program thus can thus creates a template of the software resource in a safe manner without necessarily affecting the volume at which the preparation program runs.
This application is a continuation of U.S. patent application Ser. No. 14/966,766, filed on Dec. 11, 2015, which is a continuation of U.S. patent application Ser. No. 11/393,585, filed on Mar. 30, 2006, now U.S. Pat. No. 9,213,542, Issued on Dec. 15, 2015, the entireties of which are incorporated herein by reference.
BACKGROUND Background and Relevant ArtThere are a number of ways to distribute different types of resources (software, hardware, or combinations thereof) in a computerized environment. From a software standpoint, for example, an enterprise might install multiple copies of the operating system (or application program) on multiple different computers, and thereby distribute one copy among many systems. Along these lines, the enterprise may also need to install several additional software updates to the copied or shared operating system, and thus also share multiple copies of these updates among the many systems. Conventional ways of sharing hardware include setting up computer systems on a network so that multiple different computer systems can access another computer's drive space for various storage or file sharing needs.
Additional ways of distributing resources from a combined software and hardware standpoint include creating unique entities on a single physical computer system, where the entities behave as separate and independent computer systems, but share the same physical media and processing resources. For example, an enterprise might create multiple virtual machines on at the same single server, each of which can be separately addressed by another computer as if each given virtual machine were its own separate computer system. In one such implementation, one or few servers in a large enterprise can also host several virtual machines on the same set of hardware, where those virtual machines can each serve as additional servers, or network accessible personal computers, however configured.
One will understand that such entities as virtual machines combine the sharing of software and hardware resources since they are typically set up with an existing copy of an operating system used by another virtual machine, and since they may even share a drive that is already being used by the other virtual machine. Despite sharing the same operating system, however, the enterprise will need to customize aspects of the operating system so that the virtual machine is not confused with other virtual machines using the same copy of the operating system, particularly when installed on the same physical drive. To create a customized virtual machine, therefore, a system administrator will need to provide the new virtual machine with unique indicia that distinguishes it from other virtual machines (or other computer systems), such as machine name, time zone, domain name, company name, product keys, and the like.
Simply customizing the virtual machine, however, can be fairly difficult. For example, the system administrator may desire to simply install the virtual machine from a basic installation copy of an operating system, and then apply all the various software patches of interest, as well as unique virtual machine indicia. Of course, this can be fairly inconvenient if there are a large number of software patches and other unique customizations that the system administrator would like to apply. Thus, the system administrator may prefer to copy one instance of an operating system that has already been customized to the system administrator's preferences from a software standpoint, and then install that copy in the new virtual machine albeit with different unique indicia. As such, the system administrator will need to remove the custom indicia from the existing copy-of-interest before installing that copy in the new virtual machine.
Nevertheless, there are different difficulties with simply removing customized indicia from one operating system copy and then adding new customized indicia to the operating system copy on a new virtual machine. In particular, conventional preparation software that might be used to create a “generic” or “template” copy of an operating system (or application) can be difficult to use, and can take a significant amount of time. For example, a system administrator might need to start up a copy of the operating system of interest, and then run certain preparation software on top of the operating system while it is running. As the preparation software removes certain unique features of the operating system copy, the preparation software may require the operating system to reboot several times until all unique features have been removed.
Besides the difficulties inherent in continually restarting the operating system (or application) due to simple delay, conventional preparation software can also be technically complex and difficult to use. In particular, if a user fails to appropriately configure the preparation software before attempting to convert an operating system into a generic or template copy, the user may strip out items the user did not intend to strip. This could result in the user spending more time getting the operating system back to an appropriate point, or even rendering the given operating system-of-interest (or template thereof) inoperable.
Accordingly, there are a number of problems with creating new instances of entities using preexisting software that can be addressed.
BRIEF SUMMARYImplementations of the present invention solve one or more problems in the art with systems, methods, and computer program products configured to create template copies of offline resources. In particular, implementations of the present invention allow a copy of a particular resource, such as a copy of an operating system or application, to be turned into a generic or template copy of the resource in accordance with a user's specifications, and while the resource is not running (i.e., offline). Implementations of the present invention, therefore, allow a user to create as many template copies of the same resource as desired with a great deal of efficiency and configurability. Such implementations can also provide a convenient user experience toward customizing the template during the process at a later point.
For example, a method of creating a template of at least one of the one or more software resources while the at least one software resource is offline can involve identifying an offline software resource, as well as identifying one or more template settings. These template settings will generally indicate one or more indicia to be removed from the software resource. In addition, the method can involve executing at a first operating system a preparation program configured to remove indicia in accordance with the template settings. The method can also involve redirecting one or more function calls of the preparation program to the identified software resource. As such, the indicia identified by the one or more template settings are removed from the software resource, and a template of the software resource is created.
In addition, a method of duplicating a virtual machine while it is offline, such that the virtual machine and the duplicate virtual machine have distinguishable identities when running can involve receiving the identity of a virtual machine file installed on a first storage space. The method can also involve receiving one or more function calls from a preparation program installed on a second storage space, where the one or more function calls request removal of one or more indicia. In addition, the method can involve executing the one or more function calls on the virtual machine file, which can result in the removal of the requested indicia at the first storage space. Furthermore, the method can involve creating a template copy of the virtual machine file.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Additional features and advantages of exemplary implementations of the invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by the practice of such exemplary implementations. The features and advantages of such implementations may be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features will become more fully apparent from the following description and appended claims, or may be learned by the practice of such exemplary implementations as set forth hereinafter.
In order to describe the manner in which the above-recited and other advantages and features of the invention can be obtained, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
The present invention extends to systems, methods, and computer program products configured to create template copies of offline resources. In particular, implementations of the present invention allow a copy of a particular resource, such as a copy of an operating system or application, to be turned into a generic or template copy of the resource in accordance with a user's specifications, and while the resource is not running (i.e., offline). Implementations of the present invention, therefore, allow a user to create as many template copies of the same resource as desired with a great deal of efficiency and configurability. Such implementations can also provide a convenient user experience toward customizing the template during the process at a later point.
As will be understood more fully from the description and claims herein, at least one advantage of these implementations is that users (e.g., system administrators) can efficiently provide a customized virtual machine to a large number of other users without having to recreate that customized virtual machine from a base level. Furthermore, the user or owner of a customized virtual machine can easily create a template of the user's virtual machine without necessarily having to go through several reboots and/or restarts of the hardware or software associated therewith. In addition, since the process can be automated, some of the typically tough decisions to which regular users would not know the answer (such as Product Keys, DNS, WINS, etc.) can be addressed by the system automatically, ultimately saving costs, for example, in help desk or administrative calls. Still further, implementations of the present invention allow the function calls of certain preparation software to be easily redirected to another location so that the user can create a template out of a virtual machine located remotely.
As used herein, a “preparation program” refers to a set of generally independent computer-executable instructions configured to interface with a particular file as instructed by a particular user, such as an image file of a virtual machine or operating system, or an image (or executable) of an application program file. The preparation program can then, in accordance with provided template settings, remove certain customized indicia from that file. In at least one implementation with respect to the MICROSOFT operating environment for example, one preparation program (e.g., 145) that can be used in accordance with one or more implementations of the present invention is the System Preparation tool, also referred to as “Sysprep.”
In In any event, in some cases, such as described primarily herein, the preparation program will further interface with a “preparation agent.” by configuration from the user or other administrator. A preparation agent is also a set of computer-executable instructions that effectively acts as a shim interface (e.g.,
As a virtual machine, resource 140 can provide most or all of the benefits of a conventional physical machine, such as run application programs, interact with other physical or virtual machines, serve network or database applications/functions, and so on. In one implementation, for example, server 105 comprises a main partition that acts primarily as a storage server, while resource 140 acts as a mail or database server. As such, others on the network are generally unaware that resource 140 is only a virtual machine hosted by server 105, at least in part since resource 140 is sufficiently customized and independently addressable compared with other machines on the network.
By way of explanation, this particular example shows that each volume 160, 170, 175, etc. is identifiable through a particular drive letter designation. One will appreciate, however, that this is not required in accordance with implementations of the present invention. For example, a drive path can be designated by any appropriate Global Unique Identifier (“GUID”) appropriate for a given operating system. A drive path can also be designed without a GUID in other cases. For example, drive path could designate an un-mounted volume, a mounted volume without a drive letter (e.g., a mount point), a mounted volume with a drive letter, or even a transportable snapshot. Ultimately, there only need be a way of addressing the particular volume. Thus, the illustrations and designations of particular drive or file paths made herein illustrate at least one possible implementation out of descriptive convenience.
In any event, and as previously mentioned, each resource will generally be separately customized at least in terms of basic indicia that allow the resource to be distinguished by a local or remote computer system. For example,
Accordingly, the user prepares template settings 155, which target resource 140 via volume “z:\” 175, and include a specific request only to remove custom indicia “f, and g.” In one implementation, template settings 155 are simply electronic data provided to preparation program 145 and created in response to input received through a user interface. In other cases, template settings 155 can be a file or component created separately using another program, where preparation program 145 simply receives the data therein. In any event,
As shown in
Referring again to
For example, with particular respect to virtual machines, preparation program 145, via preparation agent 150, can mount any virtual hard disks (e.g., volume 175) of the corresponding resource (i.e., resource image file). Alternatively, preparation program 145 might be configured to simply read or write to the resource file without necessarily mounting the volume. Preparation program 145 can then set up preparation agent 150 with any appropriate flags, such as by initiating preparation agent 150 as a new process in a debugging mode. When initiating preparation agent 150, preparation program 145 can set up preparation agent 150 in accordance with template settings 155 to trap all calls to the file system, trap all calls to the system registry, and trap any other calls necessary to make the execution run successfully. Preparation program 145 can then begin passing the appropriate function calls to preparation agent 150, which then redirects those function calls in accordance with the set up (i.e., template settings 155). For example, commands from preparation program 145 to remove customized indicia from resource 130 are redirected instead by preparation agent 150 to resource 140.
Once the appropriate customizations have been removed,
There are a number of different ways in which the new indicia 185, 190 can be provided during a new installation of resource template 140a. As previously mentioned, for example, these settings may be provided in advance to preparation program 145 through a user interface prompt when stripping the indicia from resource 140, or can be received from a different storage medium, such as a floppy disk, at any appropriate time. In other cases, the preparation program 145 (or the like) can be used again at host 110, 115 to prompt a user for this information through an appropriate user interface at installation.
In addition, one will appreciate that there can be a number of variations on the aforementioned components and mechanisms within the context of the present invention. For example, in addition to stripping custom indicia and/or specific software components or updates from a targeted resource installed on a local volume, a system administrator can also perform such functions on remote offline resources. For example, a system administrator might use preparation program 145 and preparation agent 150 to strip certain software updates of all offline resource in a large enterprise. Similarly, the system administrator might use preparation program 145 and preparation agent 150 to strip all custom indicia from a virtual machine owned by a former employee. In addition, a system administrator might use preparation program 145 and preparation agent 150 to set up a particularly customized version of an operating system for use at personal stations around an enterprise, and then create copies that can be installed with minimal effort at east station.
Still further, individual users can use these components in various personal settings. For example, a user could create a copy of a working, updated version of an operating system that has all patches and various security software installed and configured, remove the relevant product keys, and then reinstall this copy at another friend's or family member's computer with different but valid product keys, computer names, and so on. Accordingly,
Implementations of the present invention can also be described in terms of flowcharts of one or more method comprising a series of different acts for accomplishing a particular result. In particular,
As a preliminary matter, reference is sometimes made herein to a “first,” “second,” or “third” component (e.g., first, second, or third storage space). One will appreciate, however, that such designations are merely to differentiate components, such that the “first” component or storage space need only be different from a “second” or “third” component or storage space, without regard to points at which the component might be accessed. For example, the use of a first storage space, and a second, or third storage space only means that those first, second, or third storage spaces are at least different from each other, and these designations do not require that the first, second, or third storage spaces are necessarily presented, accessed, created, or have other action performed thereon in any particular sequence or order.
For example,
Similarly,
Accordingly,
Similarly, therefore,
In addition,
Accordingly, the methods and corresponding components and schematics described herein provide one or more implementations for creating an template of an offline software resource much more efficiently than otherwise available. In particular, implementations of the present invention allow templates to created using processes that are relatively fast, reliable, and typically require no end-user interaction or credentials to perform the customization. In addition, there is no explicit need to run the software resource (i.e. the virtual machine) or install additional software components on the software resource before preparing it. Furthermore, these features can all be performed with little interface on the virtual machine, that is, without necessarily requiring user logon, user profile creation, or the like. Still further, since these preparation programs and components are generally generic enough to be used on a wide range of resources, these preparation programs and components do not necessarily need to be updated each time a corresponding target software resource undergoes a version change.
As previously mentioned, this ability to create templates in such an efficient manner can be very useful for large enterprises that wish to install particularly customized or updated software resources at various computer stations. In particular, implementations of the present invention allow such copies to be made with less time and effort than previously needed, and allow such copies to be installed to a particularly customized point also with much less time and effort than previously needed. Such advantages can be particularly helpful to duplicating virtual machines, operating systems, and application programs that may be customized from a software and/or personalization standpoint many times over during their lifetime.
By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or a combination of hardwired or wireless) to a computer, the computer properly views the connection as a computer-readable medium. Thus, any such connection is properly termed a computer-readable medium. Combinations of the above should also be included within the scope of computer-readable media.
Computer-executable instructions comprise, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.
Claims
1. A system, comprising:
- a processor; and
- a memory having instructions that configure the processor to at least:
- receive a request to create a second virtual machine from a first virtual machine based on a settings file;
- identify a first software resource installed on the first virtual machine in response to the software resource having a first set of indicia;
- remove from the software resource at least one of one the indicia based on one or more settings in the settings file;
- add to the software resource at least one of one indicia based on one or more settings in the settings file; and
- store the virtual machine with the removed and added at least one indicia as a generic virtual machine.
2. The system as recited in claim 1, wherein the first software resource is an operating system of the first virtual machine.
3. The system as recited in claim 1, wherein the first software resource is an application program installed on an operating system of the first virtual machine.
4. The system as recited in claim 1, wherein the one or more settings comprise a system or user setting comprising an indication of any one or more of computer name, user name, company name, domain name, or network address.
5. The system as recited in claim 1, wherein the one or more settings comprise a system or user setting comprising an indication of any one or more of a resource product key, a software version, or a security setting.
6. The system as recited in claim 1 wherein the memory has instructions that configure the processor to at least to instantiate the generic virtual machine as a third virtual machine.
7. The system as recited in claim 1 wherein the memory has instruction that instructions that further configure the processor to at least store the removed one or more indicia that were removed from the software resource.
8. A method, comprising:
- receiving a request to create a second virtual machine from a first virtual machine based on a settings file;
- identifying a first software resource installed on the first virtual machine in response to the software resource having a first set of indicia;
- removing from the software resource at least one of one the indicia based on one or more settings in the settings file;
- adding to the software resource at least one of one indicia based on one or more settings in the settings file; and
- storing the virtual machine with the removed and added at least one indicia as a generic virtual machine.
9. The method as recited in claim 8, wherein the first software resource is an operating system of the first virtual machine.
10. The method as recited in claim 8, wherein the first software resource is an application program installed on an operating system of the first virtual machine.
11. The method as recited in claim 8, wherein the one or more settings comprise a system or user setting comprising an indication of any one or more of computer name, user name, company name, domain name, or network address.
12. The method as recited in claim 8, wherein the one or more settings comprise a system or user setting comprising an indication of any one or more of a resource product key, a software version, or a security setting.
13. The method as recited in claim 8 further comprising instantiating the generic virtual machine as a third virtual machine.
14. The method as recited in claim 8, further comprising storing the removed one or more indicia that were removed from the software resource.
15. A computer-readable storage device excluding signals per se, the storage device having stored thereon computer readable instructions that upon execution on a computing device, causes the computing device at least to:
- receive a request to create a second virtual machine from a first virtual machine based on a settings file;
- identify a first software resource installed on the first virtual machine in response to the software resource having a first set of indicia;
- remove from the software resource at least one of one the indicia based on one or more settings in the settings file;
- add to the software resource at least one of one indicia based on one or more settings in the settings file; and
- store the virtual machine with the removed and added at least one indicia as a generic virtual machine.
16. The computer-readable storage device as recited in claim 15, wherein the first software resource is an operating system of the first virtual machine.
17. The computer-readable storage device as recited in claim 15, wherein the first software resource is an application program installed on an operating system of the first virtual machine.
18. The computer-readable storage device as recited in claim 15, wherein the one or more settings comprise a system or user setting comprising an indication of any one or more of computer name, user name, company name, domain name, or network address.
19. The computer-readable storage device as recited in claim 15, wherein the one or more settings comprise a system or user setting comprising an indication of any one or more of a resource product key, a software version, or a security setting.
20. The computer-readable storage device as recited in claim 15, the computer-readable storage device further having stored thereon computer readable instructions that upon execution on a computing device, causes the computing device at least to instantiate the generic virtual machine as a third virtual machine.
Type: Application
Filed: Feb 8, 2017
Publication Date: May 25, 2017
Inventors: Nelson S. Araujo (Redmond, WA), Steven P. Robertson (Redmond, WA)
Application Number: 15/427,681