如何在 Linux 中创建无盘 PXE 映像

如何在 Linux 中创建无盘 PXE 映像

标题是介绍:我确实需要一些 Linux 专家来解决这个问题,这不是一个显而易见的问题,或者至少对我来说不是。我很清楚如何做到这一点,并且以前也这样做过,但这次我错过了一些东西。在这种情况下,我的 pxe 映像无法启动,并且无法切换根目录。

我为创建我尝试过的当前图像所做的事情:

  1. 在目标硬件上安装并设置 Linux Redhat 版本 7。

  2. 创建了一个包含“nfs”和“网络”模块的自定义 initramfs(因此该映像从板载硬盘启动并工作。

  3. 使用 rsync cmd 复制根文件系统,然后将我的自定义 initramfs 和匹配的内核放入 pxe 的 tftpboot 服务器中。

  4. 清除 fstab 文件并注释掉硬盘驱动器的 uuid 并尝试两者(fstab 为空或 root 挂载在 nfs 上的 fstab)

  5. 更改了 initramfs 和 vmlinuz 的权限

  6. 设置 nfs 服务器服务并使用 no_root_squash 和 rw 将根文件系统设置为可导出

我遇到的问题:图像将 pxe 过来并运行 vmlinuz,然后运行 ​​initramfs,但一旦到达交换机根服务就会失败。一段时间后,它让我进入 dracut shell,我查看了 dracut 报告 /run/initramfs/rdsosreport.txt,其中一行包含以下内容

Failed to switch root: Specified switch root path '/sysroot' does not seem to be an OS tree. os-release file is missing initrd-switch-root.service: Main Process exited, code=exited, status=1/FAILURE 

我查看过,操作系统发布文件就在那里,并且与目标硬件硬盘上的工作映像上的文件相同(每次都会成功启动)。

根文件系统在那里并通过正确的绝对路径指向适当的位置,这是我的 pxelinux.cfg 默认行

root=nfs:192.9.600.5:/correct/path/to/rootfilesystem  

另外,当这行过去错误或不正确时,我会收到 dracut 致命错误,dracut 不知道如何处理 root=nfs... 等,或者如果 rootfilesystem 由于错误的路径或权限而不可用,它会吐出权限不足的错误。

我还注意到,我在切换 root 期间失去了与 pxe 服务器的连接,这可能是它失败的原因,因为 root 位于 nfs 上,但它具有 nfs 和网络模块,否则 initramfs 会在 switch-root.service 之前失败?所以我很困惑为什么我在这一点上失去了连接。特别是因为创建 pxe 映像的映像确实具有 nfs 并在启动时启用。

我对此进行了研究,但没有结果,如果有人能指出我做错了什么或帮助我发现问题的根源,我将非常感激。

答案1

它可能是 NFS 版本上的锁定。首先,手册建议使用 root=nfs:server-ip:/exported/root/directory,vers=4.2 作为引导选项。您还可以从工作系统将 /root 挂载到 /mnt 中来检查:

  1. 如果安装正确
  2. cat /proc/mounts 检查默认挂载中的 NFS 版本
  3. lsmod 可以显示实际使用了哪些模块

NFS 相当棘手,因为 NFSv4 有许多衍生品和不兼容性,而 NFSv3 需要 RPC 守护进程来工作,有时这会很混乱。运行一些无盘客户端时,我可以说 initramfs 中的模块的行为与主系统中的模块有很大不同。

您还可以尝试从 dracut 挂载 NFS 并向我们提供结果。 tcpdump 客户端流量也可以帮助查看是否发生了某些情况。

今晚我还将尝试启动现代 EL7,看看是否还有其他一些警告。

相关内容