Отладка проблем с загрузкой PXE с помощью GRUB

Я хочу загрузить текущий компакт-диск Antergos через pxe netboot. Для этого я скачал ISO, установил его и скопировал содержимое в /tftp/antergos/,

Затем я настроил dnsmasq для предложения tftp и использовал

grub-mkstandalone -d /usr/lib/grub/x86_64-efi/ -O x86_64-efi \
                  --fonts="unicode" -o bootx64.efi grub/grub.cfg

создать загрузчик EFI в /tftp/antergos/arch/boot/ из следующего grub.cfg:

set timeout=5

menuentry 'Antergos x86_64' {
     insmod net
     insmod tftp
     insmod efi_gop
     set net_default_server=192.168.0.1
     net_add_addr eno0 efinet0 192.168.0.150

        linux   (tftp)/antergos/arch/boot/vmlinuz archisobasedir=arch archisolabel=ANTERGOS modules-load=loop rd.modules-load=loop udev.log-priority=crit rd.udev.log-priority=crit quiet splash
        initrd  (tftp)/antergos/arch/boot/archiso.img
}

dnsmasq настроен на доставку bootx64.efi:

enable-tftp
tftp-root=/tftp
dhcp-option=option:Bootfile-name,"/antergos/arch/boot/bootx64.efi"
dhcp-boot=/antergos/arch/boot/bootx64.efi
dhcp-option-force=210,/antergos/
dhcp-option-force=66,192.168.0.1
dhcp-option=3,192.168.0.101

Однако, когда я выбираю загрузку pxe (IPv4) на моем компьютере, он получает bootx64.efi и затем идет прямо к раковине личинки. В скорлупе я могу cat (memdisk)/grub/grub.cfg и получить содержимое выше grub.cfg поэтому я предполагаю, что оболочка исходит от bootx64.efi а не из моей существующей локальной установки.

Как мне диагностировать, что здесь происходит не так?

2 ответа

Решение

Проблема была в том, что grub выглядит по умолчанию для grub.cfg в (memdisk)/boot/grub, Мемдиск, созданный командой в вопросе (grub-mkstandalone [...] -o bootx64.efi grub/grub.cfg) выглядело так:

- boot
- grub
 - grub.cfg

Так что личинка не найдет grub.cfg и ничего не делать.

Решение было позвонить grub-mkstandalone снаружи boot папку и передать ее как часть grub.cfg путь вроде так:

grub-mkstandalone -d /usr/lib/grub/x86_64-efi/   -O x86_64-efi  --fonts="unicode"  \
                  -o boot/bootx64.efi boot/grub/grub.cfg

который генерирует следующее (memdisk) содержание:

- boot
 - grub
  - grub.cfg

Принятый ответ решает проблему путем встраивания конфигурации вbootx64.efi(ака ), но это не единственный способ.

Убедитесь, что ваш DHCP-сервер устанавливает эту опцию. Например, с ISC DHCPd:

      next-server 192.168.0.254;

grub использует это, чтобы знать, где искать файл конфигурации, как описано здесь: https://www.gnu.org/software/grub/manual/grub/html_node/Network.html .

Если клиент скачиваетgrub.efi, но нетgrub.cfg, клиент загружаетсяgrub>быстро и$net_default_serverПустой, отсутствующий или неправильный следующий сервер, вероятно, является причиной.

      grub> echo $net_default_server

По моему опыту,$prefixвсегда будет(memdisk)путь, независимо от того,next-serverустановлено правильно, и grub загружает файл конфигурации с TFTP-сервера:

      grub> echo $prefix
(memdisk)/boot/grub
Другие вопросы по тегам