mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-26 18:05:04 +03:00 
			
		
		
		
	Fix several typos and grammar. Reviewed-by: Giuseppe Di Natale <dinatale2@llnl.gov> Reviewed by: George Melikov <mail@gmelikov.ru> Signed-off-by: Arno van Wyk <avw1987@users.noreply.github.com> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #7080
		
			
				
	
	
		
			95 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
DESCRIPTION
 | 
						|
  These scripts are intended to be used with initramfs-tools, which is a similar
 | 
						|
  software product to "dracut" (which is used in RedHat based distributions),
 | 
						|
  and is mainly used by Debian GNU/Linux and derivatives to create an initramfs
 | 
						|
  so that the system can be booted off a ZFS filesystem. If you have no need or
 | 
						|
  interest in this, then it can safely be ignored.
 | 
						|
 | 
						|
  These script were written with the primary intention of being portable and
 | 
						|
  usable on as many systems as possible.
 | 
						|
 | 
						|
  This is, in practice, usually not possible. But the intention is there.
 | 
						|
  And it is a good one.
 | 
						|
 | 
						|
  They have been tested successfully on:
 | 
						|
 | 
						|
    * Debian GNU/Linux Wheezy
 | 
						|
    * Debian GNU/Linux Jessie
 | 
						|
 | 
						|
  It uses some functionality common with the SYSV init scripts, primarily
 | 
						|
  the "/etc/zfs/zfs-functions" script.
 | 
						|
 | 
						|
FUNCTIONALITY
 | 
						|
  * Supports booting of a ZFS snapshot.
 | 
						|
    Do this by cloning the snapshot into a dataset. If this, the resulting
 | 
						|
    dataset, already exists, destroy it. Then mount it as the root filesystem.
 | 
						|
    * If snapshot does not exist, use base dataset (the part before '@')
 | 
						|
      as boot filesystem instead.
 | 
						|
    * Clone with 'mountpoint=none' and 'canmount=noauto' - we mount manually
 | 
						|
      and explicitly.
 | 
						|
    * Allow rollback of snapshots instead of clone it and boot from the clone.
 | 
						|
    * If no snapshot is specified on the 'root=' kernel command line, but
 | 
						|
      there is an '@', then get a list of snapshots below that filesystem
 | 
						|
      and ask the user which to use.
 | 
						|
 | 
						|
  * Support all currently used kernel command line arguments
 | 
						|
    * Core options:
 | 
						|
      All the different distributions have their own standard on what to specify
 | 
						|
      on the kernel command line to boot of a ZFS filesystem.
 | 
						|
 | 
						|
      Supports the following kernel command line argument combinations
 | 
						|
      (in this order - first match win):
 | 
						|
      * rpool=<pool>			(tries to finds bootfs automatically)
 | 
						|
      * bootfs=<pool>/<dataset>		(uses this for rpool - first part)
 | 
						|
      * rpool=<pool> bootfs=<pool>/<dataset>
 | 
						|
      * -B zfs-bootfs=<pool>/<fs>	(uses this for rpool - first part)
 | 
						|
      * rpool=rpool			(default if none of the above is used)
 | 
						|
      * root=<pool>/<dataset>		(uses this for rpool - first part)
 | 
						|
      * root=ZFS=<pool>/<dataset>	(uses this for rpool - first part, without 'ZFS=')
 | 
						|
      * root=zfs:AUTO			(tries to detect both pool and rootfs
 | 
						|
      * root=zfs:<pool>/<dataset>	(uses this for rpool - first part, without 'zfs:')
 | 
						|
 | 
						|
      Option <dataset> could also be <snapshot>
 | 
						|
    * Extra (control) options:
 | 
						|
      * zfsdebug=(on,yes,1)   Show extra debugging information
 | 
						|
      * zfsforce=(on,yes,1)   Force import the pool
 | 
						|
      * rollback=(on,yes,1)   Rollback (instead of clone) the snapshot
 | 
						|
 | 
						|
  * 'Smarter' way to import pools. Don't just try cache file or /dev.
 | 
						|
    * Try to use /dev/disk/by-vdev (if /etc/zfs/vdev_id.conf exists),
 | 
						|
    * Try /dev/mapper (to be able to use LUKS backed pools as well as
 | 
						|
      multi-path devices).
 | 
						|
    * /dev/disk/by-id and any other /dev/disk/by-* directory that may exist.
 | 
						|
    * Use /dev as a last ditch attempt.
 | 
						|
    * Fallback to using the cache file if that exist if nothing else worked.
 | 
						|
    * Only try to import pool if it haven't already been imported
 | 
						|
      * This will negate the need to force import a pool that have not been
 | 
						|
        exported cleanly.
 | 
						|
      * Support exclusion of pools to import by setting ZFS_POOL_EXCEPTIONS
 | 
						|
         in /etc/default/zfs.
 | 
						|
 | 
						|
    Controlling in which order devices is searched for is controlled by
 | 
						|
    ZPOOL_IMPORT_PATH variable set in /etc/defaults/zfs.
 | 
						|
 | 
						|
  * Support additional configuration variable ZFS_INITRD_ADDITIONAL_DATASETS
 | 
						|
    to mount additional filesystems not located under your root dataset.
 | 
						|
 | 
						|
    For example, if the root fs is specified as 'rpool/ROOT/rootfs', it will
 | 
						|
    automatically and without specific configuration mount any filesystems
 | 
						|
    below this on the mount point specified in the 'mountpoint' property.
 | 
						|
    Such as 'rpool/root/rootfs/var', 'rpool/root/rootfs/usr' etc)
 | 
						|
 | 
						|
    However, if one prefer to have separate filesystems, not located below
 | 
						|
    the root fs (such as 'rpool/var', 'rpool/ROOT/opt' etc), special
 | 
						|
    configuration needs to be done. This is what the variable, set in
 | 
						|
    /etc/defaults/zfs file, needs to be configured. The 'mountpoint'
 | 
						|
    property needs to be correct for this to work though.
 | 
						|
 | 
						|
  * Allows mounting a rootfs with mountpoint=legacy set.
 | 
						|
 | 
						|
  * Include /etc/modprobe.d/{zfs,spl}.conf in the initrd if it/they exist.
 | 
						|
 | 
						|
  * Include the udev rule to use by-vdev for pool imports.
 | 
						|
 | 
						|
  * Include the /etc/default/zfs file to the initrd.
 |