Я обновил ядро CentOS7 из-за проблемы с Meltdown с 3.10.0-693.11.1 до 3.10.0-693.11.6, но после этого обновления я не могу загрузиться, поскольку centos падает на dracut с ошибкой
warning /dev/mapper/centos-root does not exist
dracut:/# ls /dev/mapper/
control
dracut:/#
Похоже, мой initrd настроен неправильно, я все еще могу без проблем загрузить 3.10.0-693.11.1. Я пытаюсь отладить это (в Интернете много ресурсов), но похоже, что мне здесь что-то принципиально не хватает, так как я не могу выполнить команду lvm
dracut:/# lvm scan
sh: lvm: command not found
dracut:/# ls /etc/lvm/lvm.conf
ls: cannot access /etc/lvm/lvm.conf: No file or dictionary
dracut:/# ls /etc/lvm
ls: cannot access /etc/lvm: No file or dictionary
Я видел, что обычно проблема с инструментами вызвана отсутствием двоичных файлов в / sbin, поэтому я загрузил стабильное ядро и проверил:
root@localhost ~# ls /sbin/lvm
/sbin/lvm
root@localhost ~# which lvm
/sbin/lvm
Итак, двоичный файл находится в правильном месте, но по какой-то причине dracut не видит его внутри / sbin.
Моя конфигурация grub для 3.10.0-693.11.1 и 3.10.0-693.11.6 почти идентична
#: after update kernel params
linux16 /vmlinuz-3.10.0-693.11.6.el7.x86_64 root=/dev/mapper/centos-root ro crashkernel=128M rd.lvm.lv=centos/root rd.lvm.lv=centos/swap rdshell
#: before update kernel params
linux16 /vmlinuz-3.10.0-693.11.1.el7.x86_64 root=/dev/mapper/centos-root ro crashkernel=128M rd.lvm.lv=centos/root rd.lvm.lv=centos/swap rdshell
Здесь я немного боролся: я просмотрел страницу руководства dracut, и там много опций для LVM, я нажимаю, что автообнаружение не работает, но почему оно работает для предыдущего ядра, а у нового есть проблема? Также как я могу получить работающие инструменты lvm на initram для дальнейшей отладки?
Спасибо за любой совет!
ОБНОВЛЕНИЕ: запуск lsinitrd -m -k показывает, что внутри ramdisk нет модуля lvm
========================================================================
Image: /boot/initramfs-3.10.0-693.11.6.el7.x86_64.img: 18M
========================================================================
Early CPIO image
========================================================================
drwxr-xr-x 3 root root 0 Jan 22 11:15 .
-rw-r--r-- 1 root root 2 Jan 22 11:15 early_cpio
drwxr-xr-x 3 root root 0 Jan 22 11:15 kernel
drwxr-xr-x 3 root root 0 Jan 22 11:15 kernel/x86
drwxr-xr-x 2 root root 0 Jan 22 11:15 kernel/x86 /microcode
-rw-r--r-- 1 root root 24576 Jan 22 11:15 kernel/x86 /microcode/GenuineIntel.bin
========================================================================
Version: dracut-033-502.el7
dracut modules:
bash
nss-softokn
i18n
network
ifcfg
drm
plymouth
kernel-modules
qemu
resume
rootfs-block
terminfo
udev-rules
biosdevname
systemd
usrmount
base
fs-lib
shutdown
========================================================================
Я пытался добавить драйвер ядра lvm в образ initram, но, к сожалению, это не удалось без каких-либо видимых проблем:
dracut --add-drivers lvm /boot/initramfs-3.10.0-693.11.6.el7.x86_64.img
dracut[27939]: Failed to install module lvm
добавление -v не указывает ни на что полезное.
У меня была такая проблема. Я исправил это:
вход в live cd (восстановление тоже должно быть в порядке)
cp /etc/dracut.conf /etc/dracut.conf.bak
nano /etc/dracut.conf
Поправив следующие строки:
# dracut modules to add to the default
add_dracutmodules+="lvm"
# install local /etc/mdadm.conf
mdadmconf="yes"
# install local /etc/lvm/lvm.conf
lvmconf="yes"
(Вам, вероятно, не понадобится mdadmconf, я добавил его, так как у меня есть Raid.)
Повторно запустить dracut -f для моего ядра. Перезагрузка.
Это помогло мне решить проблему с lvm. Теперь у меня проблемы с тем, что sysroot не монтируется (он сбрасывает меня в оболочку восстановления). Я обновлю, когда исправлю.