94 lines
4.5 KiB
Markdown
94 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.
|