A computer system is loaded with an install image of system software (hereinafter, “install image”) that enables the computer system to boot and execute the system software. Presently, several techniques may be used to load an install image onto a computer system, the most popular and effective technique being compact disk (CD)-based installations and network-based installations. A CD-based installation involves inserting an installation CD into a computer system that is configured to execute installation code (hereinafter, “executable image”) stored on the installation CD.
Kernel 106 is dependent on files 110 for proper execution. Examples of such files 110 include TAR files that when extracted provide a directory used by kernel 106 to programmatically perform the loading of install image 112 into the computer system. Files 110 may also include general data that is accessible via the directory used by kernel 106 to copy install image 112 into storage device 126. Specifically, kernel 106 is configured to execute installer 108, which performs the loading of install image 112 into the computer system by copying install image 112 from memory 122 or compact disk 127 to storage device 126. When the computer system is restarted, the install image 112 is loaded into memory 122 by boot loader 120. As known in the art, install image 112 is in a format, such that when it is load into memory 112, the computer system can begin executing system software.
As mentioned above, network-based techniques may also be used to load an install image 112 into a computer system.
Extracting install image 214—which includes kernel 216, compressed files 218, and boot loader 220—from network boot server 240 provides several ease-of-use advantages. For example, an administrator does not have to burn a CD, verify it, walk over to a server in a noisy datacenter, find a terminal, power on the machine on, and wait during the installation. With network-based techniques, the entire process can be done remotely. Unfortunately, network-based techniques suffer from similar problems to those described above in conjunction with
One or more embodiments of the present invention provide a technique to install an image of system software that requires less system resources and is faster than the prior art techniques discussed above. According to one or more embodiments of the present invention, the image of the system software is generated dynamically using an installation code that is loaded into memory from an installation storage medium or server, and stored in a storage device for use in subsequent booting. In contrast to the prior art discussed above, a preconfigured install image is no longer needed. As a result, computational resources for reading the preconfigured install image into memory and copying it to a storage device are no longer required.
A method of installing an image of system software, according to an embodiment of the present invention, includes the steps of: prior to booting the system software, (i) loading an executable image of the system software using a boot loader, wherein the executable image includes a kernel of the system software, (ii) executing the kernel of the system software, and (iii) generating the image of the system software from the loaded executable image that includes a copy of the kernel; and storing the image of the system software in a storage device from which the system software is to be booted.
A method of generating an image of system software from an executable image that includes a kernel, and a plurality of files used by the kernel, according to an embodiment of the present invention, includes the steps of: generating a plurality of pointers, each pointing to a different one of the files, retrieving the files using the pointers and compressing each of the files, and storing a copy of the kernel and the compressed files in a storage device from which the system software is to be booted as the image of the system software.
Further embodiment of the present invention includes a non-transitory computer-readable storage medium storing instructions that, when executed by a processor, cause the processor to generate an image of system software from an executable image that includes a kernel and a plurality of files used by the kernel, by performing the steps of: generating a plurality of pointers, each pointing to a different one of the files, retrieving the files using the pointers and compressing each of the files, and storing a copy of the kernel and the compressed files in a storage device from which the system software is to be booted as the image of the system software.
Hardware platform 320 includes one or more central processing units (CPUs) 321, memory 322, read-only-memory (ROM) 323, one or more network interface cards (NICs) 324 that connect computer system 300 to a network 330, a storage device 326, and an external storage 327. In one embodiment, the ROM 323 includes bootstrapping software that is configured to automatically execute when computer system 300 is powered on. Such bootstrapping software is typically configured to, when storage device 326 does not contain a bootable image of system software 310, locate and execute bootable software residing on, e.g., external storage 327 or network boot server 340. External storage 327 may be any medium capable of storing data such as a CD-ROM, flash memory drive, and the like.
The aforementioned prior-art techniques of loading install images suffer from at least redundant transfer of data and networking complexities. To cure these deficiencies, embodiments of the present invention set forth a new technique described below in conjunction with
Executable image 402, when executed, causes kernel 404 to be executed. Kernel 404, when executed, causes installer 412 to be executed, and installer 412 is configured to generate install image 414 and store install image 414 in storage device 326. Prior to generating install image 414, installer 412 partitions storage device 326 based on partition table 410. In some embodiments, the partition table 410 may instead be a set of partition rules included in executable image 402 such that installer 412 may partition storage device 326 on-the-fly. Such partitions include at least a partition for kernel 408 and files that are compressed and stored as compressed files 418. However, embodiments of the invention are not limited to such partitions and may be carried out using a single partition of storage device 326. In addition, in some embodiments, the files are not compressed before they are stored in the partitions. Next, installer 412 copies kernel 408 to storage device 326. Installer 412 compresses the remainder of files 406 and stores them in storage device 326 as compressed files 418, according to a detailed technique described below in conjunction with
The various embodiments described herein may employ various computer-implemented operations involving data stored in computer systems. For example, these operations may require physical manipulation of physical quantities which usually, though not necessarily, take the form of electrical or magnetic signals where they, or representations of them, are capable of being stored, transferred, combined, compared, or otherwise manipulated. Further, such manipulations are often referred to in terms, such as producing, identifying, determining, or comparing. Any operations described herein that form part of one or more embodiments of the invention may be useful machine operations. In addition, one or more embodiments of the invention also relate to a device or an apparatus for performing these operations. The apparatus may be specially constructed for specific required purposes, or it may be a general purpose computer selectively activated or configured by a computer program stored in the computer. In particular, various general purpose machines may be used with computer programs written in accordance with the description provided herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
The various embodiments described herein may be practiced with other computer system configurations including hand-held devices, microprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
One or more embodiments of the present invention may be implemented as one or more computer programs or as one or more computer program modules embodied in one or more computer readable media. The term computer readable medium refers to any data storage device that can store data which can thereafter be input to a computer system; computer readable media may be based on any existing or subsequently developed technology for embodying computer programs in a manner that enables them to be read by a computer. Examples of a computer readable medium include a hard drive, network attached storage (NAS), read-only memory, random-access memory (e.g., a flash memory device), a CD-ROM (Compact Disc-ROM), a CD-R, or a CD-RW, a DVD (Digital Versatile Disc), a magnetic tape, and other optical and non-optical data storage devices. The computer readable medium can also be distributed over a network coupled computer system so that the computer readable code is stored and executed in a distributed fashion.
Although one or more embodiments of the present invention have been described in some detail for clarity of understanding, it will be apparent that certain changes and modifications may be made within the scope of the claims. Accordingly, the described embodiments are to be considered as illustrative and not restrictive, and the scope of the claims is not to be limited to details given herein, but may be modified within the scope and equivalents of the claims. In the claims, elements and/or steps do not imply any particular order of operation, unless explicitly stated in the claims.
Plural instances may be provided for components, operations or structures described herein as a single instance. Finally, boundaries between various components, operations and data stores are somewhat arbitrary, and particular operations are illustrated in the context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within the scope of the invention(s). In general, structures and functionality presented as separate components in exemplary configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements may fall within the scope of the appended claims(s).
This application is a divisional application of U.S. patent application Ser. No. 13/162,430, filed on Jun. 16, 2011, granted as U.S. Pat. No. 9,158,550, which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5136711 | Hugard et al. | Aug 1992 | A |
6108697 | Raymond | Aug 2000 | A |
6591376 | VanRooven | Jul 2003 | B1 |
6965989 | Strange | Nov 2005 | B1 |
7330967 | Pujare et al. | Feb 2008 | B1 |
7334157 | Graf et al. | Feb 2008 | B1 |
7409494 | Edwards | Aug 2008 | B2 |
7565517 | Arbon | Jul 2009 | B1 |
7600005 | Jamkhedkar et al. | Oct 2009 | B2 |
20040123286 | Kang | Jun 2004 | A1 |
20050060528 | Kim | Mar 2005 | A1 |
20050132123 | Glaum | Jun 2005 | A1 |
20050132179 | Glaum | Jun 2005 | A1 |
20050246401 | Edwards | Nov 2005 | A1 |
20050262502 | Lari | Nov 2005 | A1 |
20060101259 | Chen | May 2006 | A1 |
20060259754 | Miller et al. | Nov 2006 | A1 |
20060294515 | Gimpl | Dec 2006 | A1 |
20070016693 | Goodrich | Jan 2007 | A1 |
20070028082 | Lien | Feb 2007 | A1 |
20070038685 | Chan | Feb 2007 | A1 |
20070055860 | Wang | Mar 2007 | A1 |
20070067679 | Deobald | Mar 2007 | A1 |
20070101119 | Vesterinen et al. | May 2007 | A1 |
20070169112 | Wu | Jul 2007 | A1 |
20080155533 | Mittapalli et al. | Jun 2008 | A1 |
20090185761 | He | Jul 2009 | A1 |
20090271173 | Vnukov | Oct 2009 | A1 |
20100058328 | DeHaan | Mar 2010 | A1 |
20100169470 | Takashige et al. | Jul 2010 | A1 |
20100174894 | Chen et al. | Jul 2010 | A1 |
20100241837 | Concorso | Sep 2010 | A1 |
20100250912 | Duncan | Sep 2010 | A1 |
20100318770 | Lin | Dec 2010 | A1 |
20110078429 | Yang et al. | Mar 2011 | A1 |
20110119348 | Gibbons | May 2011 | A1 |
20110126044 | Kim et al. | May 2011 | A1 |
20110264776 | Clerc et al. | Oct 2011 | A1 |
20110296397 | Vidal | Dec 2011 | A1 |
20110321030 | Rajan et al. | Dec 2011 | A1 |
20120047499 | Krzystofczyk | Feb 2012 | A1 |
20120151005 | Wu | Jun 2012 | A1 |
20120284495 | Domsch et al. | Nov 2012 | A1 |
20120304164 | van der Zweep | Nov 2012 | A1 |
20130132955 | Bolte | May 2013 | A1 |
20140068240 | Nightingale | Mar 2014 | A1 |
Entry |
---|
Linux Information Project, “Partition Table Definition,” 2010, pp. 1-2, downloaded from the Wayback Machine Internet Archive at <url>:https://web.archive.org/web/20100425023929/http://www.linfo.org/partition_table.html. |
Ramesh Chandra et al., “The collective: a cache-based system management architecture,” 2005, Proceedings of the 2nd conference on Symposium on Networked Systems Design & Implementation, vol. 2, pp. 259-272, downloaded from the Internet at <url>:https://dl.acm.org. (Year: 2005). |
Nan Zhang et al., “SPM-Based Boot Loader,” 2008, International Conference on Embedded Software and Systems Symposia, pp. 164-168, downloaded from the Internet at <url>:https://ieeexplore.ieee.org. (Year: 2008). |
Felix Rauch et al., “Partition Repositories for Partition Cloning—OS Independent Software Maintenance in Large Clusters of PCs,” 2000, Proceedings IEEE International Conference on Cluster Computing, pp. 233-242, downloaded from the Internet at <url>:https://ieeexplore.ieee.org. (Year: 2000). |
Chandra et al.; “The Collective: A Cache-Based System Management Architecture”; Proceedings of the 2nd conference on Symposium on Networked System Design & Implementation, vol. 2; pp. 259-272; 2005. |
Nishimura et al.; “Virtual Clusters on the Fly—Fast, Scalable, and Flexible Installation”; Seventh IEEE International Symposium on Cluster Computing and the Grid; pp. 549-556; 2007. |
Sapuntzakis et al.; “Optimizing the Migration of Virtual Computers”; ACM SIGOPS Operating System Review—OSDI '02: Proceedings of the 5th Symposium on Operating Systems Design and Implementation, vol. 36, Issue SI, Winter 2002; pp. 377-390; 2002. |
Number | Date | Country | |
---|---|---|---|
20160026474 A1 | Jan 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13162430 | Jun 2011 | US |
Child | 14876751 | US |