Mounten Sie eine verschlüsselte ZFS-Partition

Mounten Sie eine verschlüsselte ZFS-Partition

Ich muss also eine verschlüsselte ZFS-Partition mounten, um meinen Computer zu reparieren. Ich habe überall gesucht, aber ich kann sie mit den gefundenen Informationen nicht mounten. Jedes Mal, wenn ich sudo zfs set mountpoint=/mnt/k/ rpooles tue, schlägt es nicht fehl, aber ich kann nicht auf die Dateien zugreifen. Wenn ich sie auf Datenträger mounte, erhalte ich error mounting /dev/sda4 to /media/ubuntu/rpool2: unknown filesystem type zfs_member (udisk-error-quark, 0). Höchstwahrscheinlich wird die Partition nicht gemountet, weil sie verschlüsselt ist. Wie mounte ich sie?

Antwort1

Mit dem folgenden Beispiel-Workflow können Sie Folgendes durchführen:

  1. Installieren Sie ZFS und überprüfen Sie die Installation
  2. Suchen und Importieren eines ZFS-Pools aus einer Festplattenpartition
  3. Legen Sie den Einhängepunkt des gewünschten ZFS-Pools und/oder Datasets fest.
  4. Entschlüsseln Sie den ZFS-Pool-Schlüsselspeicher
  5. Mounten Sie den Chiffrierschlüssel und laden Sie ihn in ZFS
  6. Mounten Sie Ihren ZFS-Pool und/oder Datensatz am gewünschten Punkt
ZFS_DISK='/dev/sdX'
ZFS_POOL_PARTITION='/dev/sdXn'
ZFS_POOL='rpool'
ZFS_POOL_DATASET='DATA'  # 'ROOT' or 'USERDATA' for Ubuntu
MOUNTPOINT='/mnt'

# install zfs (using apt-get, yum, dnf, pacman, etc)
sudo apt-get install zfsutils-linux
sudo zfs --version

# locate zfs disk and pool
sudo lsblk -af "$ZFS_DISK"
sudo fdisk -l "$ZFS_DISK"
 
# create mountpoint directories for zfs pool and cipher key
sudo mkdir -p "$MOUNTPOINT"
sudo mkdir -p /zfskey
 
# import pool from partition
sudo zpool import -d "$ZFS_POOL_PARTITION" "$ZFS_POOL"
sudo zpool list
sudo zpool status -P "$ZFS_POOL"

# get and set the mountpoint for our zfs pool/dataset
# NOTE: mountpoints may collide with current filesystem,
# as mountpoints inherit from higher-level mountpoints
sudo zfs get mounted "$ZFS_POOL" -t filesystem -r
sudo zfs get mountpoint "$ZFS_POOL" -t filesystem -r
sudo zfs get mountpoint "$ZFS_POOL/$ZFS_POOL_DATASET"  # BACKUP THIS VALUE
sudo zfs set mountpoint="$MOUNTPOINT" "$ZFS_POOL/$ZFS_POOL_DATASET"
 
# decrypt zfs keystore and load cipher key
sudo cryptsetup open "/dev/zvol/$ZFS_POOL/keystore" zfskey  # creates /dev/dm-0 dm-1 dm-2
ls -l /dev/mapper/zfskey  # /dev/mapper/zfskey -> /dev/dm-n
sudo cryptsetup -v status zfskey
sudo mount /dev/mapper/zfskey /zfskey
df -H
ls -l /zfskey
sudo cat /zfskey/system.key | sudo zfs load-key -L prompt "$ZFS_POOL"

# mount the decrypted pool and/or dataset
sudo zfs mount "$ZFS_POOL/$ZFS_POOL_DATASET"
sudo zfs list
ls -la "$MOUNTPOINT"

Ihr Verzeichnis sollte jetzt gemountet und sichtbar sein.

verwandte Informationen