.. highlight:: sh Preparation ====================== .. contents:: Table of Contents :local: #. Disable Secure Boot. ZFS modules can not be loaded if Secure Boot is enabled. #. Download a variant of Fedora 34 live image and boot from it. - `Fedora Workstation (GNOME) `__ - `Fedora Spins (Xfce, i3, ...) `__ #. Set root password or ``/root/.ssh/authorized_keys``. #. Start SSH server:: echo PermitRootLogin yes >> /etc/ssh/sshd_config systemctl start sshd #. Connect from another computer:: ssh root@192.168.1.19 #. Temporarily set SELinux to permissive in live environment:: setenforce 0 SELinux will be enabled on the installed system. #. Install ``kernel-devel``:: source /etc/os-release dnf install -y https://dl.fedoraproject.org/pub/fedora/linux/releases/${VERSION_ID}/Everything/x86_64/os/Packages/k/kernel-devel-$(uname -r).rpm #. Add ZFS repo:: dnf install -y https://zfsonlinux.org/fedora/zfs-release.fc${VERSION_ID}.noarch.rpm #. If zfs-fuse from official Fedora repo is installed, remove it first. It is not maintained and should not be used under any circumstance:: dnf remove -y zfs-fuse #. Install ZFS packages:: dnf install -y zfs #. Load kernel modules:: modprobe zfs #. Install helper script and partition tool:: dnf install -y arch-install-scripts gdisk dosfstools #. Target Fedora version:: INST_FEDORA_VER='34' #. Unique pool suffix. ZFS expects pool names to be unique, therefore it's recommended to create pools with a unique suffix:: INST_UUID=$(dd if=/dev/urandom bs=1 count=100 2>/dev/null | tr -dc 'a-z0-9' | cut -c-6) #. Identify this installation in ZFS filesystem path:: INST_ID=fedora #. Target disk List available disks with:: ls /dev/disk/by-id/* If using virtio as disk bus, use ``/dev/disk/by-path/*``. Declare disk array:: DISK='/dev/disk/by-id/ata-FOO /dev/disk/by-id/nvme-BAR' For single disk installation, use:: DISK='/dev/disk/by-id/disk1' #. Choose a primary disk. This disk will be used for primary EFI partition and hibernation, default to first disk in the array:: INST_PRIMARY_DISK=$(echo $DISK | cut -f1 -d\ ) #. Set vdev topology, possible values are: - (not set, single disk or striped; no redundancy) - mirror - raidz1 - raidz2 - raidz3 :: INST_VDEV= This will create a single vdev with the topology of your choice. It is also possible to manually create a pool with multiple vdevs, such as:: zpool create --options \ poolName \ mirror sda sdb \ raidz2 sdc ... \ raidz3 sde ... \ spare sdf ... Notice the cost of parity when using RAID-Z. See `here `__ and `here `__. For boot pool, which must be readable by GRUB, mirrored vdev should always be used for maximum redundancy. This guide will use mirrored bpool for multi-disk setup. Refer to `zpoolconcepts `__ and `zpool-create `__ man pages for details. #. Set partition size: Set ESP size:: INST_PARTSIZE_ESP=2 # in GB Set boot pool size. To avoid running out of space while using boot environments, the minimum is 4GB. Adjust the size if you intend to use multiple kernel/distros:: INST_PARTSIZE_BPOOL=4 Set swap size. It's `recommended `__ to setup a swap partition. If you intend to use hibernation, the minimum should be no less than RAM size. Skip if swap is not needed:: INST_PARTSIZE_SWAP=8 Root pool size, use all remaining disk space if not set:: INST_PARTSIZE_RPOOL=