Схема моего единственного диска следующая:
/dev/sda1 for the plaintext boot partition
/dev/sda2 for the encrypted root partition
Моя система - ArchLinux, и я следовал этому руководству, чтобы настроить корневое шифрование (без lvm, без raid). Вот что я сделал: запустил cryptsetup
на /dev/sda2
и сопоставил его с /dev/mapper/cryptroot
Мой /etc/fstab
выглядит так:
UUID=of /dev/mapper/cryptroot / ext4 rw,relatime,data=ordered,discard 0 1
UUID=of /dev/sda1 /boot ext4 rw,relatime,data=ordered,discard 0 2
В моем /etc/default/grub
я изменил одну строку следующим образом:
GRUB_CMDLINE_LINUX="cryptdevice=UUID of /dev/sda2:cryptroot:allow-discards"
В /etc/mkinitcpio.conf
хуки выглядят так:
HOOKS="base udev autodetect modconf block encrypt filesystems keyboard fsck"
Наконец, я не забыл запустить mkinitcpio -p linux
и grub-mkconfig -o /boot/grub/grub.cfg
соответственно.
Я перечислил свои действия таким быстрым способом, потому что ранее я успешно настраивал шифрование для моей корневой файловой системы. Итак, в конце я получаю следующую ошибку:
ERROR: device *UUID of /dev/mapper/cryptroot* not found. Skipping fsck.
ERROR: unable to find root device *UUID of /dev/mapper/cryptroot*
You are being dropped into recovery shell
Странно то, что он пытается найти незашифрованный /dev/mapper/cryptroot
но при этом не запрашивает у меня пароль (который я создал, когда cryptsetup
/dev/sda2
в начале). Поэтому, естественно, он не может найти незашифрованное блочное устройство, потому что он не запрашивал у меня пароль. Не могли бы вы сказать мне, что я настроил неправильно?