每个人似乎都在使用 GRUB 通过 PXE 从网络启动 UEFI 机器。虽然它有效,但它缺乏一个能够立即指导某些已知客户的重要功能。GRUB 立即发出请求grub/grub.cfg
。
PXELINUX 具有以下功能:在加载“默认”配置之前,它会尝试一些源自客户端 MAC 地址和 IP 地址的特殊名称。例如,对于具有 IP 172.31.1.38
(十六进制AC1F0126
)和 MAC 的客户端BC:24:11:21:4D:14
,它将尝试按以下顺序从 TFTP 服务器加载配置:
pxelinux.cfg/01-bc-24-11-21-4d-14
pxelinux.cfg/AC1F0126
pxelinux.cfg/AC1F012
pxelinux.cfg/AC1F01
pxelinux.cfg/AC1F0
pxelinux.cfg/AC1F
pxelinux.cfg/AC1
pxelinux.cfg/AC
pxelinux.cfg/A
pxelinux.cfg/default
因此,使用 PXELINUX,我可以为某些已知客户端创建专用配置文件,其中可以包含对专门为该客户端制作的 preseed 或 kickstart 脚本的引用。它将执行完全无人值守的系统安装,所有这些都用于自动化(既生成虚拟机又准备裸机服务器)。当安装开始时,它只是删除这个专用的引导加载程序配置,因此下次机器将从网络启动,但现在它将命中default
指示从本地硬盘启动的配置文件。事实上,我运行这样的基础设施已经有 10 多年了,非常棒。
但现在我们需要为 UEFI 客户端提供相同的功能,而 PXELINUX 似乎不适用于 UEFI。
有没有办法与 GRUB PXE 具有类似的功能,能够对 UEFI 客户端执行相同的操作,以便请求专用配置文件,或者使用通用客户端中特定于客户端的“默认”引导菜单选项配置文件?
或者,也许还有另一个 UEFI PXE 引导加载程序可以这样做?
实际上GRUB支持与PXELinux相同的配置文件方案。GRUB 手册中对此进行了描述。
我没有碰巧看到它工作,因为我使用了 Ubuntu 中的一些随机构建的 GRUB,它似乎忽略了这个功能。另外,手册中存在差异:它说我们必须命名文件
grub.cfg-<MAC>
,从示例中可以清楚地看出,应该用MAC地址替换,其中冒号:
用破折号替换-
,所有“字母”都用十六进制替换更改为小写,如下所示:grub.cfg-52-54-00-ec-33-81
。但实际上,GRUB 请求了该文件grub.cfg-01-<MAC>
(至少,我的 GRUB 是在 Gentoo 中内置的,并且大部分都是默认的 USE 标志),例如,就我而言,它非常grub.cfg-01-bc-24-11-5b-65-e5
像 PXELinux 那样。另外,尽管手册中已声明,但我的 GRUB 并未请求该文件grub.cfg-<UUID>
。但它要求所有grub.cfg-<IP_part>
变体完全按照手册中的描述(grub.cfg-AC1F0134
,grub.cfg-AC1F013
依此类推,对于172.31.1.52
)。