暗号化されたzfsパーティションをマウントする

暗号化されたzfsパーティションをマウントする

コンピューターを修復するには、暗号化された zfs パーティションをマウントする必要があります。あちこち調べましたが、見つけた情報ではマウントできません。毎回マウントしてもsudo zfs set mountpoint=/mnt/k/ rpool失敗はしませんが、ファイルにアクセスできません。ディスクにマウントすると、 が表示されますerror mounting /dev/sda4 to /media/ubuntu/rpool2: unknown filesystem type zfs_member (udisk-error-quark, 0)。パーティションが暗号化されているため、マウントできない可能性が高いです。マウントするにはどうすればよいでしょうか?

答え1

以下のサンプルワークフローを使用して、次の操作を実行できます。

  1. ZFSをインストールし、インストールを確認する
  2. ディスクパーティションからZFSプールを見つけてインポートする
  3. 目的のZFSプールおよび/またはデータセットのマウントポイントを設定します
  4. ZFSプールキーストアを復号化する
  5. 暗号鍵をマウントしてZFSにロードする
  6. ZFSプールやデータセットを目的のポイントにマウントします
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"

これでディレクトリがマウントされ、表示されるようになります。

関連情報