PXE无人值守自动化灌装
什么是PXE
PXE is Pro-Boot Execution Environment
- 进行 PXE 安装的必要条件是在要安装的计算机中必须包含一个 PXE 支持的网卡(NIC),即网卡中必须要有 PXE Client。PXE 协议可以使计算机通过网络启动。
- 此协议分为 Client端和 Server 端,而PXE Client则在网卡的 ROM 中。当计算机引导时,BIOS 把 PXE Client 调入内存中执行,然后由 PXE Client 将放置在远端的文件通过网络下载到本地运行。
- 运行 PXE 协议需要设置 DHCP 服务器和 TFTP 服务器。
- DHCP 服务器会给 PXE Client(将要安装系统的主机)分配一个 IP 地址,由于是给 PXE Client 分配 IP 地址,所以在配置 DHCP 服务器时需要增加相应的 PXE 设置。此外,在 PXE Client 的 ROM 中,已经存在了 TFTP Client,那么它就可以通过 TFTP 协议到 TFTP Server 上下载所需的文件了。
PXE的工作过程
- PXE Client 从自己的PXE网卡启动,向本网络中的DHCP服务器索取IP;
- DHCP 服务器返回分配给客户机的IP 以及PXE文件的放置位置(该文件一般是放在一台TFTP服务器上) ;
- PXE Client 向本网络中的TFTP服务器索取pxelinux.0 文件;
- PXE Client 取得pxelinux.0 文件后之执行该文件;
- 根据pxelinux.0 的执行结果,通过TFTP服务器加载内核和文件系统;
- 进入安装画面, 此时可以通过选择HTTP、FTP、NFS 方式之一进行安装;
详细工作流程,请参考下面这幅图:
什么是Kickstart
Kickstart是一种无人值守的安装方式。它的工作原理是在安装过程中记录典型的需要人工干预填写的各种参数,并生成一个名为ks.cfg的文件。如果在安装过程中(不只局限于生成Kickstart安装文件的机器)出现要填写参数的情况,安装程序首先会去查找Kickstart生成的文件,如果找到合适的参数,就采用所找到的参数;如果没有找到合适的参数,便需要安装者手工干预了。所以,如果Kickstart文件涵盖了安装过程中可能出现的所有需要填写的参数,那么安装者完全可以只告诉安装程序从何处取ks.cfg文件,然后就去忙自己的事情。等安装完毕,安装程序会根据ks.cfg中的设置重启系统,并结束安装。
PXE+Kickstart 无人值守安装操作系统完整过程如下:
安装DHCP + tftp
YUM 安装信息
1 | yum install -y dhcp tftp-server vim lrzsz xinetd net-tools syslinux rsync system-config-kickstart httpd |
其他操作
关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
关闭selinux
sed -i “s/enforcing/disabled/g” /etc/selinux/config
setenforce 0
配置DHCP
1 | [root@localhost dhcp]# cat dhcpd.conf |
配置
1 | [root@localhost dhcp]# cat dhcpd.conf |
systemctl enable dhcpd
systemctl start dhcpd
监听端口
netstat -tulnp |grep :67
配置tftp,// tftp服务提供压缩内核和系统引导程序
1 | root@localhost ~]# cat /etc/xinetd.d/tftp |
配置
修改这一项为”disable =no”
1 | [root@localhost ~]# systemctl start tftp |
监听端口
netstat -tulnp |grep :69
pxelinux.0 网络引导程序
1 | [root@localhost tftpboot]# pwd |
查看下pxelinux.0文件是否存在
yum install mlocate -y yum源处已经添加
1 | [root@localhost tftpboot]# locate pxelinux.0 |
pxelinux.0路径/usr/share/syslinux/pxelinux.0
拷贝pxelinux.0到/var/lib/tftpboot
1 | [root@localhost tftpboot]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/ |
传统linux操作系统启动
1.BIOS自检
2.读取引导程序
2.1 GRUb(一段固定的可执行代码)
2.2 BIOS执行引导程序
2.3 引导程序读取配置文件(/boot/grub/grub.conf)
PXE
1.客户端启动系统,选择网卡启动
2.从DHCP服务器中获取到了IP地址等信息
3.还获取到了tftp server及网络引导程序pxelinux.0
4.通过网卡读取到tftp server(/var/lib/tftpboot)上的pxelinux.0,读取到内存中
5.在内存中执行引导程序
6.读取引导程序的配置文件(var/lib/tftpboot/pxelinux.0/default)
7.读取default内容
挂载ios镜像
mount -o loop CentOS-7-x86_64-Minimal-1908.iso /mnt/
配置pxelinux.cfg 文件
mkdir /var/lib/tftpboot/pxelinux.cfg
1 | [root@localhost isolinux]# cp isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default |
已经可以看到安装界面
扩展多个安装系统
这里面最重要的文件,vmlinuz initd.img
vmlinuz 内核
initd.img 驱动程序,一定要匹配OS
ios镜像挂载后,可以看到一个image文件夹,里面有个pxeboot
1 | [root@localhost mnt]# ls |
在/var/lib/tftpboot下创建一个kilig的文件夹
把vmlinuz initd.img拷贝到这个文件夹下
仿写安装界面
1 | #cp /media/images/pxeboot/{initrd.img,vmlinuz} /var/lib/tftpboot/ |
system-config-kickstart配置和httpd配置
安装system-config-kickstart httpd
1 | [root@localhost mnt]# systemctl enable httpd |
安装桌面
tftp客户端测试:tftp
1
2
3
4
5
6
7yum -y install tftp
cd /var/lib/tftpboot
touch tftp.test
cd
tftp 10.1.255.166
tftp> get tftp.test
tftp> quit
1 | systemctl start xinetd httpd dhcpd tftp |