Я следовал эти шаги , чтобы создать зашифрованный жесткий диск USB на Lubuntu 13.10, и это , чтобы разблокировать его с файл_ключа вместо ключевой фразы. Теперь у меня есть диск /dev /disk /by-uuid /32f692ec-e22c-49d3-b6cf-f90e605a5b48, который является необработанным зашифрованным устройством, /dev /backup /backup, который является открытым текстом, и /mnt /backup, где находится файловая система. установлен Диск представляет собой обычный жесткий диск SATA, подключенный через адаптер USB3.
У меня нет проблем с использованием или монтированием диска; проблема заключается в попытке автоматически смонтировать его при загрузке. Я добавил его в мой fstab и crypttab, как предполагает статья:
$ cat /etc/fstab
# /etc/fstab: static file system information.
#
# Use 'blkid' to print the universally unique identifier for a
# device; this may be used with UUID= as a more robust way to name devices
# that works even if disks are added and removed. See fstab(5).
#
# <file system> <mount point> <type> <options> <dump> <pass>
/dev/mapper/sda2_crypt / ext4 errors=remount-ro 0 1
# /boot was on /dev/sda1 during installation
UUID=8afa992c-9174-4a70-b9a0-1ac25b42dbaf /boot ext2 defaults 0 2
/dev/mapper/sdb2_crypt /home ext4 defaults 0 2
/dev/mapper/sdb1_crypt /var ext4 defaults 0 2
/dev/backup/backup /mnt/backup ext4 defaults 0 3
$ cat /etc/crypttab
sda2_crypt UUID=6450d0e6-539b-4fa0-a9e1-f06edfbb5ba9 none luks
sdb1_crypt UUID=f30e6efe-8e58-42b6-aed0-dc7999510744 /root/keyfile luks
sdb2_crypt UUID=17f1f107-8f05-4dbd-8172-4d595411d874 /root/keyfile luks
backup UUID=32f692ec-e22c-49d3-b6cf-f90e605a5b48 /root/keyfile luks
(Может быть, "резервная копия" не является правильным именем в /etc /crypttab? У меня нет /dev /sda2_crypt.)
При этом он просто зависает при загрузке, говоря «диск для /mnt /backup не готов или отсутствует».
Я подумал, что диск к тому времени не готов, поэтому я попытался смонтировать его в /etc/rc.local:
$ cat /etc/rc.local
#!/bin/sh -e
#
# rc.local
#
# This script is executed at the end of each multiuser runlevel.
# Make sure that the script will "exit 0" on success or any other
# value on error.
#
# In order to enable or disable this script just change the execution
# bits.
#
# By default this script does nothing.
logger Mounting backup disk...
ls -l /dev/disk/by-uuid/ > /home/rena/disk-uuid.txt
stat /root/keyfile >> /home/rena/disk-uuid.txt
whoami >> /home/rena/disk-uuid.txt
cryptsetup --verbose --key-file=/root/keyfile luksOpen /dev/disk/by-uuid/32f692ec-e22c-49d3-b6cf-f90e605a5b48 backup
logger Unlocked OK.
mount /dev/backup/backup /mnt/backup/
logger Mounted OK.
exit 0
По выводу системного журнала я вижу, что он разблокируется, но не монтируется. Похоже, что весь скрипт rc.local просто умер, когда достиг этой строки. Я также вижу по ls, stat и whoami, что диск действительно присутствует в листинге, ключевой файл доступен, и скрипт выполняется от имени пользователя root. Так что я не знаю, почему монтаж не удастся.
Самое странное, если я удалю все это из rc, local и просто введу команды в терминале после загрузки:
sudo cryptsetup --verbose --key-file=/root/keyfile luksOpen /dev/disk/by-uuid/32f692ec-e22c-49d3-b6cf-f90e605a5b48 backup
sudo mount /dev/backup/backup /mnt/backup/
Монтируется нормально. Так почему же он не работает в rc.local и в fstab/crypttab?