Setting up ZFS with native encryption: Difference between revisions

From Alpine Linux
(added and replaced categories)
(added redirect to ZFS page as the content from here has been moved to that page)
Tag: New redirect
 
Line 1: Line 1:
This is a guide for creating and auto-mounting an encrypted ZFS drive or partition on an existing encrypted alpine linux system, using ZFS's own encryption capabilities. If you want to make a fresh install with the root partition on ZFS, see [[Root on ZFS with native encryption]].
#REDIRECT [[ZFS]]
 
The system will be encrypted when powered off but will not require you to type an extra password at boot, since it uses a key stored on the encrypted root partition. Alternative options are also given, such as prompting for a password at boot rather than storing the key on the root drive. The example in this guide is modeled around creating a ZFS filesystem to be used as a user's home directory, but it can be trivially modified to create a filesystem for other purposes.
 
= Preparation =
 
Every command in this guide should be run as root.
 
    apk update
    apk add zfs zfs-lts  # install the utilities
    modprobe zfs        # load the kernel modules
    mdev -s              # make sure the device nodes are present
 
== Create an encryption key ==
 
This section can be skipped if you intend to unlock the drive by typing a password rather than unlocking automatically. You should use a password instead if your root partition is not encrypted. The location "/etc/home.key" can be anything.
 
    dd if=/dev/random of=/etc/home.key bs=32 count=1
    chmod 600 /etc/home.key
 
IMPORTANT: Make sure you don't lose this key by overwriting your root filesystem or anything like that. You might want to store a copy of it on an encrypted USB drive, for instance.
 
= ZFS setup =
 
== Create the zpool ==
 
Replace `/dev/sd...` with the name of the disk or partition where you would like to make the zfs filesystem, such as `/dev/nvme0n1` or `/dev/sda1`. If you would like to be prompted for a password at boot rather than using the key as generated above, then replace `-O keylocation=file:///etc/home.key -O keyformat=raw` with `-O keylocation=prompt -O keyformat=passphrase`. The name "homepool" can be anything.
 
    zpool create -o ashift=12 -O acltype=posixacl -O compression=lz4 \
    -O dnodesize=auto -O normalization=formD -O relatime=on -O xattr=sa \
    -O encryption=aes-256-gcm -O keylocation=file:///etc/home.key -O keyformat=raw \
    -O mountpoint=none homepool /dev/sd...
 
After completing this, confirm that the pool has been created:
 
    zpool status
 
Should return something like:
 
      pool: homepool
    state: ONLINE
    config:
   
            NAME        STATE    READ WRITE CKSUM
            homepool    ONLINE      0    0    0
              sd...    ONLINE      0    0    0
   
    errors: No known data errors
 
== Create and mount the filesystem ==
 
    zfs create -o mountpoint=/home/username homepool/username
    chown username:username /home/username  # likely unnecessary if not creating a homedir
 
== Set up the services to auto-mount the new filesystem ==
 
    rc-update add zfs-import    # import existing zpools
    rc-update add zfs-load-key  # load the encryption keys
    rc-update add zfs-mount    # mount the filesystems
 
Finally,
 
    reboot
 
[[Category:Storage]]
[[Category:Installation]]
[[Category:Security]]

Latest revision as of 09:57, 2 April 2025

Redirect to: