Схема моего единственного диска следующая:
/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 в начале). Поэтому, естественно, он не может найти незашифрованное блочное устройство, потому что он не запрашивал у меня пароль. Не могли бы вы сказать мне, что я настроил неправильно?
