A subscription-based image pack service program provides the service of automated creation of computer software production images for different customers. To build a production image, a user interacts with the image pack service to enter selections of components and settings to be included in the production image. The image pack service automatically retrieves the selected components and builds the production image using the components. The image pack service keeps track of configuration information of the production image it has built, and notifies the user of recent changes/updates relating to the components and settings used in the production image. The user then decides whether the production image should be modified to incorporate the changes and, if so, uses the image pack service to generate the updated production image.
|
1. A computer program product for use at an organizational computer system, the organizational computer system communicatively coupled to an image pack service, the computer program product for implementing a method for automatically building a single production software image file from user selected software components so as to significantly reduce the resources expended by the organization to build a production software image file, the production software image file for distribution to any of a number of the organization's computer systems, the computer program product comprising one or more computer-readable storage medium having stored thereon computer-executable instructions that, when executed by a processor, cause the computer system to perform the following:
receive user input signing up an organization to subscribe with a service provider of an image pack service such that the organization can use the image pack service to automatically build production software image files tailored for installation on any number of the organization's computer systems based on components identified by the organization to the image pack service;
in response to receiving the user input, send subscription information to the service provider of the image pack service and receive authorization from the service provider to user the image pack service to build the production software image file;
the image pack service receiving, through a user-interface of the image pack service, user input selecting components for inclusion in a production software image file, the selected components including at least a computer operating system and one or more third-party software components that will run on the operating system along with configuration settings for the computer operating system and the one or more third-party software components, the user input identifying one or more network locations external to the organization for accessing the one or more third-party software components that are to be built into in the production software image file;
the image pack service automatically retrieving the selected components including retrieving the one or more third-party software components from the identified one or more network locations external to the organization in response to receiving the user input component selections at the user interface of the image pack service;
the image pack service automatically building a combination of the organizational computer operating system, the retrieved one or more third-party software components and the configuration settings for the computer operating system and the one or more third-party software components into a single production software image file in response to receiving the user input component selections at the user interface of the image pack service, the single production software image file tailored for installation on any of a plurality of the organization's existing production computer systems so as to facilitate a uniform configuration across the plurality of the organization's existing computer systems;
the image pack service notifying the user of one or more recommended changes that are to be made to the production software image file;
the image pack service receiving an indication from the user that the changes recommended by the image pack service are to be made to the production software image file; and
the image pack service creating a new version of the production software image file that incorporates the recommended changes.
12. An organizational computer system embedded in one or more computer-readable storage media, the system configured to manage automated generation of computer software production software image files, the system configured to automatically build production software image files from user selected software components for use on any number of computers within an organization so as to significantly reduce the resources expended by the organization to build a production software image file, the production software image file for distribution to the organization's computer systems, comprising:
an image pack service provided for use by a user of a customer organization for generating production software images for the customer organization, the image pack service being operable in connection with a subscription to a service provider of the image pack service and configured to perform the steps of:
receiving user input signing up an organization to subscribe to the service provider of the image pack service such that the organization can use the image pack service to automatically build production software image files tailored for installation on any number of the organization's computer systems and having components identified by the organization to the image pack service;
in response to receiving user input signing up the organization, sending subscription information to the service provider of the image pack service and receiving authorization from the service provider to user the image pack service to build the production software image file
receiving, through a user interface of the image pack service, user input selecting components for inclusion in a production software image file, the selected components including at least a computer operating system and one or more third-party software components that will run on the operating system along with configuration settings for the computer operating system and the one or more third-party software components, the user input identifying one or more network locations external to the organization for accessing third-party software components;
automatically retrieve the selected components including one or more third-party software components from the identified one or more network locations external to the organization in response to receiving the user input component selections at the user interface of the image pack service;
automatically build a combination of the computer operating system, the one or more third-party software components and the configuration settings for the computer operating system and one or more third-party software components into a single production software image file in response to receiving user input component selections at the user interface of the image pack service, the single production software image file tailored for installation on any of a plurality of the organizations existing computer systems so as to facilitate a uniform configuration of the organization's third-party software components across the plurality of the organization's computer systems;
notify the user of one or more recommended changes that are to be made to the production software image file;
receive an indication from the user that the changes recommended by the image pack service are to be made to the production software image file; and
create a new version of the production software image file that incorporates the recommended changes; and
a database for maintaining configuration information of the user selected components built into the single production software image.
9. At an organizational computer system communicatively coupled to a subscription-based service provider of an image pack service installed at the organizational computer system, a method of automatically building a production software image file from user selected software components so as to significantly reduce the resources expended by an organization to build a production software image file, the production software image file for distribution to the organization's computer systems, the method comprising:
receiving user input signing up an organization to subscribe to the image pack service such that the organization can use the image pack service to automatically build production software image files tailored for installation on any number of the organization's computer systems based on components identified by the organization to the image pack service;
in response to receiving the user input, sending subscription information to the service provider of the image pack service and receiving authorization from the service provider to user the image pack service to build the production software image file;
the image pack service receiving, through a user interface of the image pack service, user input selecting components for inclusion in a production software image, the selected components including at least a computer operating system, including a version of the computer operating system and versions of service packs and quick fix engineering (QFE) packets for the computer operating system, and one or more third-party software components that will run on the operating system along with configuration settings for the computer operating system and the one or more third-party software components, the user input identifying one or more network locations external to the organization for accessing third-party software components that are to be built into the production software image file;
the image pack service automatically retrieving the selected components including retrieving one or more third-party software components from the identified one or more network locations external to the organization in response to receiving the user input component selections at the user interface of the image pack service;
the image pack service automatically building a combination of the organizational computer operating system, the retrieved one or more third-party software components and the configuration settings for the computer operating system and the one or more third-party software components into a single production software image file in response to receiving the user input component selections at the user interface of the image pack service, the single production software image file for installation on any of a plurality of the organization's existing computer systems so as to facilitate a uniform configuration across the plurality of the organization's existing computer systems;
receiving, by the image pack service, a request to modify the single production software image file, the request corresponding to feedback from an iterative testing procedure for testing a single production software file within designated test machines within the organization;
rebuilding, by the image pack service, the single production software image file according to the request to modify the single production software image file;
the image pack service automatically tracking change/update information for the components built into the single production software image file in response to receiving the user input component selections at the user interface of the image pack service such that no subsequent interaction with the production computer systems is required to identify applicable updates to the selected components built into the single production software image file;
receiving information regarding changes and updates available for components built into the single production software image file;
the image pack service automatically generating notification for notifying the organization of one or more recommended changes and updates available for the components built into the single production software image file;
the image pack service receiving an indication from the user that the changes recommended by the image pack service are to be made to the production software image file; and
the image pack service creating a new version of the production software image file that incorporates the recommended changes.
2. The computer program product as recited in
3. The computer program product as recited in
maintain configuration information of the single production software image file in a database;
receive information regarding changes and updates available for the organization's selected components included in the single production software image file; and
generate notification for notifying a user of the changes and updates available for the selected components included in the single production software image file.
4. The computer program product as recited in
5. The computer program product as recited in
6. The computer program product as recited in
install the single production software image file to a first computer system to facilitate uniform computer system configuration between the first computer system and other computer systems within the plurality of computer systems; and
subsequently install the single production software image file to a second computer system to facilitate uniform computer system configuration between the second computer system and the first computer system.
7. The computer program product as recited in
receiving an indication that at least one of a component and a setting in the production image file is to be modified; and
building a new version of the production image to incorporate the requested modifications.
8. The computer program product as recited in
10. A method as in
11. A method as in
13. A system as in
automatically tracking change/update information for the components built into the single production software image file in response to receiving the user input component selections at the user interface of the image pack service such that no subsequent interaction with the production computer systems is required to identify applicable updates to the selected components built into the single production software image;
receiving information regarding changes and updates available for approved components built into the single production software image filer; and
generating notification for notifying a representative of the customer organization of the changes and updates.
14. A system as in
|
This invention relates generally to the installation of software components on computers, and more particularly to a system and method for providing the service of automated creation of software production images in accordance with different requirements of customers.
In large corporations or other types of organizations that each employs hundreds or thousand of computers, it is often desirable to ensure that all the servers or desktops are configured identically to ensure uniformity in the operations of the computers and to simplify the tasks of maintaining and trouble-shooting the computers. To that end, it is common for a corporation to install a uniform computer software image on all of their servers or desktop computers. Such a uniform software image, often called a “production image,” typically includes the operation system, applications, hardware drivers, particular registry setting and other settings, etc. Because each corporation has its own particular needs and preferences, the production image has to be built around the different components selected to suit the requirements of that corporation. Today, it is typical for each of the corporations using production images to have its own internal team and internal procedures for building its production image, and for testing the image built by the team to ensure that the computer systems (server and desktop) in production are standardized and up to date. Each production image is typically built “manually” by the team by putting together all the required components to create the production image. Such a process can be very time consuming and expensive. Moreover, it is often difficult for the team responsible for developing the production image to learn about new changes/updates made to the components and settings used in the production image.
In view of the foregoing, the present invention provides a system and method for providing the service of automated creation of production images for different customers. To use the service, a customer has to first subscribe to the service. The service is implemented in an image pack service program. To build a production image, a user uses the user interface of the image pack service to select the components to be included in the production image. The image pack service then automatically retrieves the components and builds the production image using the components. The production image built by the image pack service can then be tested, modified, and finalized by the customer. The image pack service keeps track of the configuration information of the production image it has built, and notifies the user of recent changes/updates for the components and settings used in the production image. The user can then make the decision of whether to modify the existing production image to incorporate the changes.
Turning to the drawings, wherein like reference numerals refer to like elements, the invention is illustrated as being implemented in a suitable computing environment. Although not required, the invention will be described in the general context of computer-executable instructions, such as program modules, being executed by a personal computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations, including hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. The invention may be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
The following description begins with a description of a general-purpose computing device that may be used in an exemplary system for implementing the invention, and the image pack service of the invention will be described in greater detail with reference to
The hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 are connected to the system bus 23 by a hard disk drive interface 32, a magnetic disk drive interface 33, and an optical disk drive interface 34, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer readable instructions, data structures, program modules and other data for the personal computer 20. Although the exemplary environment described herein employs a hard disk 60, a removable magnetic disk 29, and a removable optical disk 31, it will be appreciated by those skilled in the art that other types of computer readable media which can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories, read only memories, storage area networks, and the like may also be used in the exemplary operating environment.
A number of program modules may be stored on the hard disk 60, magnetic disk 29, optical disk 31, ROM 24 or RAM 25, including an operating system 35, one or more applications programs 36, other program modules 37, and program data 38. A user may enter commands and information into the personal computer 20 through input devices such as a keyboard 40 and a pointing device 42. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 21 through a serial port interface 46 that is coupled to the system bus, but may be connected by other interfaces, such as a parallel port, game port or a universal serial bus (USB) or a network interface card. A monitor 47 or other type of display device is also connected to the system bus 23 via an interface, such as a video adapter 48. In addition to the monitor, personal computers typically include other peripheral output devices, not shown, such as speakers and printers.
The personal computer 20 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 49. The remote computer 49 may be another personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the personal computer 20, although only a memory storage device 50 has been illustrated in
When used in a LAN networking environment, the personal computer 20 is connected to the local network 51 through a network interface or adapter 53. When used in a WAN networking environment, the personal computer 20 typically includes a modem 54 or other means for establishing communications over the WAN 52. The modem 54, which may be internal or external, is connected to the system bus 23 via the serial port interface 46. In a networked environment, program modules depicted relative to the personal computer 20, or portions thereof, may be stored in the remote memory storage device. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
In the description that follows, the invention will be described with reference to acts and symbolic representations of operations that are performed by one or more computers, unless indicated otherwise. As such, it will be understood that such acts and operations, which are at times referred to as being computer-executed, include the manipulation by the processing unit of the computer of electrical signals representing data in a structured form. This manipulation transforms the data or maintains it at locations in the memory system of the computer, which reconfigures or otherwise alters the operation of the computer in a manner well understood by those skilled in the art. The data structures where data is maintained are physical locations of the memory that have particular properties defined by the format of the data. However, while the invention is being described in the foregoing context, it is not meant to be limiting as those of skill in the art will appreciate that various of the acts and operations described hereinafter may also be implemented in hardware.
Referring to
To create a production image, a user 80 (e.g., an information technology professional (“ITPRO”) at the customer company) uses a user interface 86 of the image pack service 70 to select components to be included in the production image and the settings of the components. The components may include, for example, the operating system (e.g., the Microsoft Windows operating system) to be used as the basic platform, the various service packs of the operating system, applications (e.g., Microsoft Exchange), service packs of the applications, hardware drivers specific to the hardware to be used by the customer, etc. After the user enters the selections of components and settings, the image pack service 70 creates a production image based on the user selections. In a preferred embodiment, the image pack service 70 automatically retrieves the components selected by the user, and uses the components to build the production image 100 on a selected machine 102. The component retrieval may involve, for instance, the access of a site 106 on a network 108 where a particular selected component 112 is stored. The network 108 may be, for instance, the Internet, where the location of that component is identified by a universal resource locator (URL). Additionally, the component may reside on the internal corporate network 116 of the customer organization. After retrieving the components selected by the user 80, the image pack service 70 builds the production image 100.
Producing a production image that can be used across the organization of the customer organization is typically an iterative process that requires testing and rebuilding the image (e.g., to include service packs) multiple times. Each time a component or setting has to be modified, the user 80 indicates the changes to the image pack service 70, which then builds a new version of the production image to incorporate the changes.
By way of example, a scenario is described herein in connection with
Ira realizes that Acme also uses a different monitoring application that is unique to Acme and there is an update to that package. Ira has tested that update package and feels confident about its stability. The image pack service 70 accepts “Additional Custom Contents,” and Ira enters the location of the network site from which the new monitoring application update can be downloaded. Ira then clicks a button in the user interface 86 to initiate the build process. In response, the image pack service 70 automatically collects (step 154) all the above information from various locations that Ira has “approved,” and then creates a production image from the components (step 156).
The image pack service 70 builds this production image 100 and makes it available on a shared machine 102 to be executed. Execution of this new production image 100 would perform checks to ensure that the hardware that the image is being run on is what the image pack service built it. If the new production image passes the checks, Ira then hands off this image pack as a Bronze version (step 158) to the internal testing team of Acme, which uses this image to test various applications, response, uptime etc. (step 160).
Based on test findings, Ira updates the configuration, settings and builds of the various components and uses the image pack service 70 to create (step 162) updates to the Bronze build of the production image. After a sufficient amount of testing, Ira's information technology group promotes the Bronze (Alpha) build to Silver (Beta) status (step 166) and shares it with other teams to test with their custom applications in their departments (step 168). Ira updates the configuration (step 170) again based on the testing feedback from the teams across the organization, and finally they put an escrow build image out as Gold production image (step 172). After the escrow period, the Gold image is installed on the production servers (step 178).
Referring back to
In an alternative embodiment, the information about the configuration of the production image of the customer is stored in a database 132 at the service provider company 76. To that end, the image pack service 70 transmits the configuration information of the production image it has created to the service provider company. In this embodiment, the notification 130 of the changes are generated at the service provider company, which then sends the notification over the network 108 to the image pack service, which then forwards the notification to the user 80.
Continuing the scenario from above, Ira gets an email notification 130 (step 180) from the image pack service that there has been an update to one of the components of the Gold production image that Acme has used to standardize their systems on. Ira logs on to the image pack service 70, which tells him via the user interface that there has been a new QFE or driver or ROM or ISV agent released that could change the GOLD configuration. Ira reviews the changes and the specific area that the new update modifies, and checks to see if that involves functionality that systems in Acme use. If Ira decides that the production image should be updated (step 182), Ira uses an option in the image pack service to create an “update” image that could be used to replace the existing GOLD image after adequate testing. He selects the option, and the image pack service 70 rebuilds the custom image pack for Acme. In doing so, the image pack service remembers/tracks the revisions numbers between the different GOLD images. Ira then releases this update image as a BRONZE (Alpha) or SILVER (Beta) image, depending on how much of a change the update has performed. After final testing and approval from other teams, Ira signs off this update image package as the GOLD package to replace the older GOLD package.
The service provider company may also provide the service of building the images for customers. To provide that service, the service provider company (the ABC Corporation, or “ABC,” in the scenario) may be required to do a few things on the back end. Some of those are listed below, but it should be appreciated that the list is not exhaustive. Continuing the scenario, ABC first internally identifies several (e.g., 3-5) top standard hardware models within a vendor's product line that are used by customers who will subscribe to the service. ABC then creates images for the selected hardware models using the released updates for: N & N-1 version of the operating system; appropriate version of the Service Packs; versions of Security Rollup Packs; specific QFE packets that have been released since the last production update; firmware updates from the hardware vendor; updates to OEM drivers, agents and utilities; and changes to default registry settings, local security policy and core service configuration that are considered “best practices” overall or applicable to a general server type, like IIS or SQL. ABC tests this image to ensure that it works appropriately with the above platforms. Based on the pass criterion, the image pack service team at ABC may certify a build and the components to be stable. This is a requirement for the image and the components to be pushed out to the customer. This production image is then pushed to customers who have subscribed to the image pack service. Customers will then use this tested “image pack” and make minor modifications and then follow it up with their own internal testing.
The image pack service of the invention is expected to provide significant values to the customers. First, it reduces the cost of the customers in constructing the production images tailored to their needs by offloading much of the burden associated with developing and testing a production image for a standard hardware model within a vendor's product line. Second, the customers who subscribe to the service are kept current on any changes that might affect their production systems. Furthermore, it should be easier to maintain platform security, increase availability of a well-tested and holistically managed platform, and decrease administrative and operational burden with consolidated updates.
In view of the many possible embodiments to which the principles of this invention may be applied, it should be recognized that the embodiments described herein with respect to the drawing figures are meant to be illustrative only and should not be taken as limiting the scope of the invention. Therefore, the invention as described herein contemplates all such embodiments as may come within the scope of the following claims and equivalents thereof.
Patent | Priority | Assignee | Title |
10503495, | Aug 02 2017 | Accenture Global Solutions Limited | Component management platform |
11055090, | Aug 02 2017 | Accenture Global Solutions Limited | Component management platform |
11893383, | Dec 09 2020 | ADP, INC. | Configuration properties management for software |
7660882, | Jun 10 2004 | Cisco Technology, Inc | Deploying network element management system provisioning services |
7779404, | Jun 10 2004 | Cisco Technology, Inc | Managing network device configuration using versioning and partitioning |
7853676, | Jun 10 2004 | Cisco Technology, Inc | Protocol for efficient exchange of XML documents with a network device |
7853945, | Feb 22 2006 | Microsoft Technology Licensing, LLC | Integrated computer server imaging |
7996830, | Jun 05 2006 | International Business Machines Corporation | Programming model generic application deployment |
8074214, | May 19 2005 | Oracle International Corporation | System for creating a customized software installation on demand |
8090806, | Jun 10 2004 | Cisco Technology Inc | Two-stage network device configuration process |
8099715, | Jun 15 2006 | Hitachi, LTD | Service-based software designing assistance method and apparatus thereof |
8104031, | Jan 30 2007 | Fujitsu Limited | Storage system, storage unit, and method for hot swapping of firmware |
8214398, | Feb 16 2005 | EMC IP HOLDING COMPANY LLC | Role based access controls |
8219807, | Dec 17 2004 | JPMORGAN CHASE BANK, N A , AS SUCCESSOR AGENT | Fine grained access control for linux services |
8271785, | Dec 20 2004 | JPMORGAN CHASE BANK, N A , AS SUCCESSOR AGENT | Synthesized root privileges |
8352935, | May 19 2005 | JPMORGAN CHASE BANK, N A , AS SUCCESSOR AGENT | System for creating a customized software distribution based on user requirements |
8387038, | Aug 14 2006 | Caterpillar Inc | Method and system for automatic computer and user migration |
8468518, | May 19 2005 | Oracle International Corporation | System and method for creating a customized installation on demand |
8676973, | Mar 07 2006 | RPX Corporation | Light-weight multi-user browser |
Patent | Priority | Assignee | Title |
5937189, | Nov 12 1996 | International Business Machines Corporation | Object oriented framework mechanism for determining configuration relations |
6049665, | Oct 15 1996 | GOOGLE LLC | Object oriented framework mechanism for order processing including pre-defined extensible classes for defining an order processing environment |
6104874, | Oct 15 1996 | International Business Machines Corporation | Object oriented framework mechanism for order processing including pre-defined extensible classes for defining an order processing environment |
6151643, | Jun 07 1996 | McAfee, Inc | Automatic updating of diverse software products on multiple client computer systems by downloading scanning application to client computer and generating software list on client computer |
6381742, | Jun 19 1998 | Microsoft Technology Licensing, LLC | Software package management |
6405364, | Aug 31 1999 | Accenture Global Services Limited | Building techniques in a development architecture framework |
6658644, | Dec 29 1999 | Qwest Communications International Inc | Services-based architecture for a telecommunications enterprise |
6785805, | Aug 08 2000 | AEROFLEX SYSTEMS GROUP, INC | Network-based configuration method for systems integration in test, measurement, and automation environments |
6948169, | Nov 16 2000 | Dell Products L.P. | Web-based factory manufacturing of computers in a build-to-order manufacturing environment |
7003759, | Jun 21 2001 | SYNOPSIS, INC; Synopsys, Inc | Collection makefile generator |
20030046681, | |||
20030220853, | |||
20040003388, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Apr 11 2003 | Microsoft Corporation | (assignment on the face of the patent) | / | |||
Apr 11 2003 | IYER, KRISHNAN P | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 013975 | /0618 | |
Oct 14 2014 | Microsoft Corporation | Microsoft Technology Licensing, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034766 | /0001 |
Date | Maintenance Fee Events |
Mar 11 2009 | ASPN: Payor Number Assigned. |
Oct 29 2012 | REM: Maintenance Fee Reminder Mailed. |
Mar 17 2013 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Mar 17 2012 | 4 years fee payment window open |
Sep 17 2012 | 6 months grace period start (w surcharge) |
Mar 17 2013 | patent expiry (for year 4) |
Mar 17 2015 | 2 years to revive unintentionally abandoned end. (for year 4) |
Mar 17 2016 | 8 years fee payment window open |
Sep 17 2016 | 6 months grace period start (w surcharge) |
Mar 17 2017 | patent expiry (for year 8) |
Mar 17 2019 | 2 years to revive unintentionally abandoned end. (for year 8) |
Mar 17 2020 | 12 years fee payment window open |
Sep 17 2020 | 6 months grace period start (w surcharge) |
Mar 17 2021 | patent expiry (for year 12) |
Mar 17 2023 | 2 years to revive unintentionally abandoned end. (for year 12) |