iPXE 可实现无本地存储的网络启动与操作系统安装,需准备启动镜像、部署 HTTP/TFTP 服务、编写交互式启动脚本、支持 ISO 直启或内核级安装、配置 DHCP 链式加载,并启用调试日志定位问题。
如果您希望在无本地存储设备的环境中通过网络启动并安装操作系统,iPXE 提供了一种灵活且功能强大的解决方案。以下是实现该目标的具体操作步骤:
iPXE 需要一个可引导的固件镜像(如 ipxe.lkrn 或 ipxe.usb),并依赖后端服务提供启动脚本和操作系统安装文件。HTTP 或 TFTP 服务用于托管这些资源,确保客户端能按路径获取所需内容。
1、下载官方编译好的 iPXE 镜像,例如 ipxe.lkrn(适用于 PXE 环境链式加载)或 ipxe.usb(用于制作 U 盘启动盘)。
2、部署轻量级 HTTP 服务(如 Python 的 http.server 或 nginx),将 iPXE 脚本(如 boot.ipxe)和内核/镜像文件置于根目录下,确保可通过 http://192.168.1.100/boot.ipxe 正常访问。
3、若使用 TFTP,安装 tftpd-hpa,将 ipxe.krn 和相关内核放入 /var/tftpboot/,并确认 tftpd 服务已启用且防火墙放行 UDP 69 端口。
iPXE 脚本是实现多系统选择与自动化安装的核心,它支持变量、条件判断与菜单交互,允许用户在启动时动态选择目标操
作系统。
1、创建文本文件 boot.ipxe,以 #!ipxe 开头声明为 iPXE 脚本格式。
2、在脚本中使用 menu 指令定义启动选项,例如 “Ubuntu 22.04 安装”、“Debian 12 Live”、“Windows PE 10”。
3、为每个选项配置 kernel 与 initrd 加载路径,并附加必要启动参数,如 autoinstall ds=nocloud-net;s=http://192.168.1.100/ubuntu/ 实现无人值守安装。
部分发行版不提供分离的 vmlinuz/initrd,需通过 memdisk 或 isoloop 方式挂载完整 ISO;另一些则支持直接加载压缩内核与 initramfs,跳过 ISO 解包步骤。
1、对于 CentOS Stream 9,从镜像中提取 isolinux/vmlinuz 和 isolinux/initrd.img,上传至 HTTP 服务,并在 iPXE 脚本中指定其 URL。
2、对于 Ubuntu Server 24.04,使用 linux 命令加载 casper/vmlinuz,用 initrd 加载 casper/initrd,并添加参数 boot=casper netboot=nfs nfsroot=192.168.1.100:/nfs/ubuntu/。
3、对 Windows 部署,使用 iPXE 加载 winpe.wim(经 wimboot 封装),或调用 sanboot 直接从 iSCSI LUN 启动已预置的 Windows 安装环境。
传统 PXE ROM 仅支持加载 NBP(Network Bootstrap Program),需借助 DHCP 选项将客户端引导至自定义 iPXE 镜像,从而接管后续全部启动逻辑。
1、在 DHCP 服务器(如 dnsmasq 或 ISC dhcpd)中设置 option 66 为 TFTP 服务器地址,option 67 为 ipxe.krn 路径。
2、若使用 dnsmasq,添加配置行:dhcp-match=set:ipxe,175,175 和 dhcp-boot=tag:ipxe,http://192.168.1.100/boot.ipxe,实现智能识别与重定向。
3、重启 DHCP 服务,并验证客户端 PXE 启动日志中是否出现 iPXE 1.21.1+ (g8a5e) 及成功获取 boot.ipxe 的 HTTP 200 响应。
iPXE 默认不输出详细执行过程,启用内置日志功能可定位脚本语法错误、网络超时或路径不可达等典型问题。
1、在 iPXE 命令行中输入 set debug http://192.168.1.100/debug.log,将所有网络请求与脚本执行痕迹写入远程日志文件。
2、在脚本开头添加 #!ipxe --debug,强制开启全局调试模式,使控制台显示每一行命令解析结果。
3、使用 imgstat 查看当前已加载镜像状态,用 ifstat 确认网卡已获取 IP 并处于活动状态,避免因基础网络异常导致后续步骤失败。