mirror of
				https://github.com/xcat2/xcat-core.git
				synced 2025-10-26 17:05:33 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			195 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			195 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| =head1 NAME
 | |
| 
 | |
| B<genimage> - Generates a stateless image to be used for a diskless install.
 | |
| 
 | |
| =head1 SYNOPSIS
 | |
| 
 | |
| B<genimage>
 | |
| 
 | |
| B<genimage> [B<-o> I<osver>] [B<-a> I<arch>] [B<-p> I<profile>] [B<-i> I<nodebootif>] [B<-n> I<nodenetdrivers>] [B<--onlyinitrd>] [B<-r> I<otherifaces>] [B<-k> I<kernelver>] [B<-g> I<krpmver>] [B<-m> I<statelite>] [B<-l> I<rootlimitsize>] [B<--permission> I<permission>] [B<--interactive>] [B<--dryrun>] [B<--ignorekernelchk>] [B<--noupdate>] I<imagename>
 | |
| 
 | |
| 
 | |
| B<genimage> [B<-h> | B<--help> | B<-v> | B<--version>]
 | |
| 
 | |
| 
 | |
| =head1 DESCRIPTION
 | |
| 
 | |
| Generates a stateless and a statelite image that can be used to boot xCAT nodes in a diskless mode.
 | |
| 
 | |
| B<genimage> will use the osimage definition for information to generate this image.  Additional options specified on the command line will override any corresponding previous osimage settings and will be written back to the osimage definition.
 | |
| 
 | |
| If B<genimage> runs on the management node, both the I<osimage> table and I<linuximage> table will be updated with the given values from the options.
 | |
| 
 | |
| The B<genimage> command will generate two initial ramdisks, B<initrd-stateless.gz> for B<stateless> mode, and B<initrd-statelite.gz> for B<statelite> mode.
 | |
| 
 | |
| After your image is generated, you can chroot to the image, install any additional software you would like, or make modifications to files, and then run the following command to prepare the image for deployment.
 | |
| 
 | |
| for stateless: B<packimage>
 | |
| 
 | |
| for statelite: B<liteimg>
 | |
| 
 | |
| Besides prompting for some parameter values, the B<genimage> command takes default guesses for the parameters not specified or not defined in the I<osimage> and I<linuximage> tables. It also assumes default answers for questions from the yum/zypper command when installing rpms into the image. Use B<--interactive> flag if you want the yum/zypper command to prompt you for the answers.
 | |
| 
 | |
| If B<--onlyinitrd> is specified, genimage only regenerates the initrd for a stateless image to be used for a diskless install.
 | |
| 
 | |
| The B<genimage> command must be run on a system that is the same architecture and same distro with same major release version as the nodes it will be used on.  If the management node is not the same architecture or same distro level, copy the contents of
 | |
| /opt/xcat/share/xcat/netboot/<os> to a system that is the proper architecture, and mount /install from
 | |
| the management node to that system. Then change directory to /opt/xcat/share/xcat/netboot/<os> and run ./genimage.
 | |
| 
 | |
| 
 | |
| =head1 Parameters
 | |
| 
 | |
| I<imagename> specifies the name of an os image definition to be used. The specification for the image is stored in the I<osimage> table and I<linuximage> table.
 | |
| 
 | |
| 
 | |
| =head1 OPTIONS
 | |
| 
 | |
| =over 12
 | |
| 
 | |
| =item B<-a> I<arch>
 | |
| 
 | |
| The hardware architecture of this node: ppc64le, x86_64, ppc64, x86, ia64, etc.  If omitted, the current hardware architecture will be used.
 | |
| 
 | |
| =item B<-o> I<osver>
 | |
| 
 | |
| The operating system for the image: rhels8.2.0, sle15, ubuntu18.04.2, etc.  The OS packages must be in
 | |
| /install/<osver>/<arch> (use L<copycds(8)|copycds.8>).
 | |
| 
 | |
| =item B<-p> I<profile>
 | |
| 
 | |
| The profile (e.g. compute, service) to use to create the image.  This determines what package lists are
 | |
| used from /opt/xcat/share/xcat/netboot/<os> to create the image with.  When deploying nodes with this image,
 | |
| the nodes' nodetype.profile attribute must be set to this same value.
 | |
| 
 | |
| =item B<-i> I<nodebootif>
 | |
| 
 | |
| This argument is now optional, and allows you to specify the network boot interface to be configured in the image (e.g. eth0). If not specified, the interface will be determined and configured during the network boot process.
 | |
| 
 | |
| =item B<-n> I<nodenetdrivers>
 | |
| 
 | |
| This argument is now optional, and allows you to specify the driver
 | |
| modules needed for the network interface(s) on your stateless nodes.  If
 | |
| you do not specify this option, the default is to include all recent IBM
 | |
| xSeries network drivers.
 | |
| 
 | |
| If specified, I<nodenetdrivers> should be a comma separated list of
 | |
| network drivers to be used by the stateless nodes (Ie.: -n tg3,e1000).
 | |
| Note that the drivers will be loaded in the order that you list them,
 | |
| which may prove important in some cases.
 | |
| 
 | |
| =item B<-l> I<rootlimit>
 | |
| 
 | |
| The maximum size allowed for the root file system in the image.  Specify in bytes, or can append k, m, or g.
 | |
| 
 | |
| =item B<--onlyinitrd>
 | |
| 
 | |
| Regenerates the initrd for a stateless image to be used for a diskless install.
 | |
| 
 | |
| 
 | |
| Regenerates the initrd that is part of a stateless/statelite image that is used to boot xCAT nodes in a stateless/statelite mode.
 | |
| 
 | |
| The B<genimage --onlyinitrd> command will generate two initial ramdisks, B<initrd-stateless.gz> for B<stateless> mode, and B<initrd-statelite.gz> for B<statelite> mode.
 | |
| 
 | |
| =item B<--permission> I<permission>
 | |
| 
 | |
| The mount permission of B</.statelite> directory for B<statelite> mode, which is only used for B<statelite> mode, and the default permission is 755.
 | |
| 
 | |
| =item B<-r> I<otherifaces>
 | |
| 
 | |
| Other network interfaces (e.g. eth1) in the image that should be configured via DHCP.
 | |
| 
 | |
| =item B<-k> I<kernelver>
 | |
| 
 | |
| Use this flag if you want to use a specific version of the kernel in the image.  Defaults to the first kernel found
 | |
| in the install image.
 | |
| 
 | |
| =item B<-g> I<krpmver>
 | |
| 
 | |
| Use this flag to specify the rpm version for kernel packages in the image. It must be present if -k flag is specified in the command for SLES. Generally, the value of -g is the part after B<linux-> and before B<.rpm> in a kernel rpm name.
 | |
| 
 | |
| =item B<-m> statelite
 | |
| 
 | |
| This flag is for Ubuntu, Debian and Fedora12 only. Use this flag to specify if you want to generate statelite image. The default is to generate stateless image for these three operating systems. For others, this flag is invalid because both stateless and statelite images will be generated with this command.
 | |
| 
 | |
| =item B<--interactive>
 | |
| 
 | |
| This flag allows the user to answer questions from yum/zypper command when installing rpms into the image. If it is not specified, '-y' will be passed to the yum command and '--non-interactive --no-gpg-checks' will be passed to the zypper command as default answers.
 | |
| 
 | |
| =item B<--dryrun>
 | |
| 
 | |
| This flag shows the underlying call to the os specific genimage function. The user can copy and the paste the output to run the command on another machine that does not have xCAT installed.
 | |
| 
 | |
| 
 | |
| =item B<-t> I<tmplimit>
 | |
| 
 | |
| (Deprecated) This flag allows the user to setup the /tmp and the /var/tmp file system sizes. This flag is no longer supported. You can overwrite any file system size using the .postinstall script where you can create a new /etc/fstab file.
 | |
| 
 | |
| =item B<--ignorekernelchk>
 | |
| 
 | |
| Skip the kernel version checking when injecting drivers from osimage.driverupdatesrc. That means all drivers from osimage.driverupdatesrc will be injected to initrd for the specific target kernel.
 | |
| 
 | |
| =item B<--noupdate>
 | |
| 
 | |
| This flag allows the user to bypass automatic package updating when installing other packages.
 | |
| 
 | |
| =item B<-v|--version>
 | |
| 
 | |
| Display version.
 | |
| 
 | |
| =item B<-h|--help>
 | |
| 
 | |
| Display usage message.
 | |
| 
 | |
| =back
 | |
| 
 | |
| 
 | |
| =head1 RETURN VALUE
 | |
| 
 | |
| 0 The command completed successfully.
 | |
| 
 | |
| 1 An error has occurred.
 | |
| 
 | |
| 
 | |
| =head1 EXAMPLES
 | |
| 
 | |
| =over 3
 | |
| 
 | |
| =item 1
 | |
| To prompt the user for inputs:
 | |
| 
 | |
|   genimage
 | |
| 
 | |
| =item 2
 | |
| To generate an image using information from an osimage definition:
 | |
| 
 | |
|   genimage myimagename
 | |
| 
 | |
| =item 3
 | |
| To run genimage in test mode without actually generating an image:
 | |
| 
 | |
|   genimage --dryrun  myimagename
 | |
| 
 | |
| =item 4
 | |
| To generate an image and have yum/zypper prompt for responses:
 | |
| 
 | |
|   genimage myimagename --interactive
 | |
| 
 | |
| =item 5
 | |
| To generate an image, replacing some values in the osimage definition:
 | |
| 
 | |
|   genimage -i eth0 -n tg3 myimagename
 | |
| 
 | |
| =back
 | |
| 
 | |
| 
 | |
| =head1 FILES
 | |
| 
 | |
| /opt/xcat/bin/genimage
 | |
| 
 | |
| /opt/xcat/share/xcat/netboot/<OS>/genimage
 | |
| 
 | |
| 
 | |
| =head1 SEE ALSO
 | |
| 
 | |
| L<packimage(1)|packimage.1>, L<liteimg(1)|liteimg.1>
 |