对于一些上下文,我是一名系统管理员学生,试图扩展我的网络知识,因为这不是我的强项。
目前,我正在试验 PXE。几天前,我设置了几台 ESXi 虚拟机,一台是 DHCP 和 TFTP 服务器,另外两台是 BIOS 和 UEFI 客户端。我设法在 BIOS 和 UEFI 机器上通过 PXE 启动 debian。
我听说了 iPXE 以及它带来的可能性(例如在 HTTP、iSCSI 上启动……)并决定试一试。目前,我仍在尝试启动我的本地 debian netboot 安装程序,我想我会在确保安装正确后测试远程文件。
在这一点上,这就是我的 DHCP conf 的样子(减去不真正感兴趣的东西):
option arch code 93 = unsigned integer 16;
class "pxe-clients" {
match if substring (option vendor-class-identifier, 0, 9) = "PXEClient";
option tftp-server-name "192.168.0.5";
next-server 192.168.0.5;
if option arch = 00:00 {
if exists user-class and option user-class = "iPXE" {
filename = "pxelinux.0";
} else {
filename = "undionly.kpxe";
}
} elsif option arch = 00:02 or option arch = 00:06 or option arch = 00:07 or option arch = 00:08 or option arch = 00:09 {
if exists user-class and option user-class = "iPXE" {
filename = "bootnetx64.efi";
} else {
filename = "ipxe.efi";
}
} else {
filename = "UNKNOWN_VCI";
}
}
192.168.0.5
是 DHCP/TFTP 服务器的 LAN IP。
至于我的 TFTP 服务器的根目录:
root@vmpxe:/srv/tftp# ls -l
total 968
lrwxrwxrwx 1 root root 37 Sep 22 14:01 bootnetx64.efi -> debian-installer/amd64/bootnetx64.efi
drwxrwxr-x 3 root root 4.0K Sep 22 00:21 debian-installer
-rw-r--r-- 1 root root 896K Sep 22 16:00 ipxe.efi
lrwxrwxrwx 1 root root 47 Sep 22 00:21 ldlinux.c32 -> debian-installer/amd64/boot-screens/ldlinux.c32
lrwxrwxrwx 1 root root 33 Sep 22 00:21 pxelinux.0 -> debian-installer/amd64/pxelinux.0
lrwxrwxrwx 1 root root 35 Sep 22 00:21 pxelinux.cfg -> debian-installer/amd64/pxelinux.cfg
-rw-r--r-- 1 root root 64K Sep 22 16:00 undionly.kpxe
-rw-rw-r-- 1 root root 64 Sep 22 00:21 version.info
同样,我坚持这样一个事实,即在 iPXE 之前,两种架构上的一切都运行良好。我所做的唯一更改是从 iPXE 的网站下载undionly.kpxe
和ipxe.efi
文件,并编辑 DHCP conf 以将文件名设置包装在if exists user-class and option user-class = "iPXE" {...} else {...}
条件中。
现在,BIOS 机器执行 PXE -> iPXE -> Debian 的 netboot 安装程序。一切正常。
但是,UEFI 机器执行 PXE -> iPXE -> grub shell。
我试图 tcpdump 进程,但没有产生任何结果:所有流量看起来都是正常的和预期的。它与我在 iPXE 之前所拥有的没有太大区别。
知道这里可能会发生什么吗?
编辑:进一步的 tcpdump 测试表明,如果没有 iPXE,我的 EFI 机器会为引导加载程序和一堆其他文件发送 RRQ 数据包,我认为这些文件由引导加载程序本身引用。但是,对于 iPXE,只有引导加载程序我只看到引导加载程序。
所以我想正确的问题是:iPXE 会发生什么,因为它不能检索标准 PXE 正确下载的所有文件?
与您的问题无关,但
用于引导 EFI64
} elsif option arch = 00:02 or option arch = 00:06 or option arch = 00:07 or option arch = 00:08 or option arch = 00:09 {
应该改为
} elsif option arch = 00:07 or option arch = 00:09 {
关于你的问题,如果你启动
bootnetx64.efi
那就是你得到的;一个蛴螬屏幕。见这里: http: //lists.ipxe.org/pipermail/ipxe-devel/2015-December/004532.html
编辑:当您根据版本加载 pxelinux.0 时,它将检索动态组件以及 pxelinux.0 菜单定义。当您加载 iPXE 时,您没有加载那些额外的文件。