目录
一、PXE概念
1.PXE基本概念
PXE(预启动执行环境)是由Intel公司开发的网络引导技术,工作在Client/Server模式,允许客户机通过网络从远程服务器下载引导镜像,并加载安装文件或者整个操作系统。
2.优点
- 规模化:同时装配多台服务器;
- 自动化:安装系统、配置各种服务;
- 远程实现:不需要光盘、U 盘等安装介质。
3. 实现PXE的前提条件
-
BIOS支持
-
网卡支持
-
需要在bios中开启开关,服务器一般没打开(bmc界面里打开)
-
有DHCP 服务器
DHCP服务用于为客户机自动分配地址、指定引导文件位置 -
安装了TFTP服务
TFTP服务(简单文件传输协议)用于提供系统内核和引导镜像的下载。
4.搭建PXE远程安装服务器
PXE 远程安装服务器集成了 CentOS 7 安装源、TFTP 服务、DHCP 服务,能够向客户机裸机发送 PXE引导程序、Linux 内核、启动菜单等数据,以及提供安装文件。
二、搭建 PXE 远程安装服务器
1. 设备一台图像化centos7,自动安装一台最小化设备
2. 需要的服务 DHCP、tftp、vsftp、syslinux、tftp-server等
3.实验步骤:
1.安装并启用TFTP服务
yum -y install tftp-server xinetd #安装 TFTP 服务
vim /etc/xinetd.d/tftp
protocol = udp #TFTP使用UDP协议
wait = no #no表示客户机可以多台一起连接,yes表示客户机只能一台一台连接
server_args = -s /var/lib/tftpboot #指定TFTP根目录(文件存储路径)
disable = no #no表示开启TFTP服务
wq
systemctl enable tftp
systemctl start tftp
systemctl start xinetd
systemctl enable xinetd #启用 TFTP 服务
2.安装并启用 DHCP 服务
yum -y install dhcp
cp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf
vim /etc/dhcp/dhcpd.conf #修改DHCP服务的配置文件
ddns-update-style none; #禁用 DNS 动态更新
next-server 20.0.0.111; #指定 TFTP 服务器的地址
filename "pxelinux.0"; #指定 PXE 引导程序的文件名
subnet 20.0.0.0 netmask 255.255.255.0 { #声明要分配的网段地址
range 20.0.0.150 20.0.0.200; #设置地址池
option routers 20.0.0.111; #默认网关地址指向TFTP服务器的IP地址
}
wq
3.准备 Linux 内核、初始化镜像文件
cd /mnt/images/pxeboot #已事先把光盘挂载到/mnt目录中
cp vmlinuz /var/lib/tftpboot/ #复制 Linux系统的内核文件 到TFTP根目录下
cp initrd.img /var/lib/tftpboot/ #复制 初始化镜像文件(linux引导加载模块)到TFTP根目录下
4.准备 PXE 引导程序
yum -y install syslinux #PXE引导程序由软件包 syslinux 提供
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/ #复制 PXE引导程序 到TFTP根目录下
5.安装FTP服务,准备CentOS 7 安装源
yum -y install vsftpd
mkdir /var/ftp/centos7
cp -rf /mnt/* /var/ftp/centos7/
systemctl start vsftpd
systemctl enable vsftpd
6.配置启动菜单文件
默认的启动菜单文件在TFTP根目录的 pxelinux.cfg子目录下,文件名为default
mkdir /var/lib/tftpboot/pxelinux.cfg
vim /var/lib/tftpboot/pxelinux.cfg/default
default auto #指定默认入口名称
prompt 1 #设置是否等待用户选择,“1”表示等待用户控制
label auto #图形安装(默认)引导入口,label 用来定义启动项
kernel vmlinuz #kernel 和 append用来定义引导参数
append initrd=initrd.img method=ftp://20.0.0.111/centos7
label linux text #文本安装引导入口
kernel vmlinuz
append text initrd=initrd.img method=ftp://20.0.0.111/centos7
label linux rescue #救援模式引导入口
kernel vmlinuz
append rescue initrd=initrd.img method=ftp://20.0.0.111/centos7
7.关闭防火墙,验证 PXE 网络安装
systemctl stop firewalld.service
setenforce 0
8.使用 VMware创建的虚拟机进行测试,虚拟机内存至少需要 2GB,否则在启动安装时可能会报错。
三、实现 Kickstart 无人值守安装
1.安装system-config-kickstart工具
yum install -y system-config-kickstart
2打开“Kickstart 配置程序”窗口
执行 “system-config-kickstart” 命令打开
3.配置kickstart选项
安装后脚本:
勾选"使用解释程序":/bin/bash
rm -rf /etc/yum.repos.d/*
echo '[local]
name=local
baseurl=ftp://20.0.0.13/centos7
enabled=1
gpgcheck=0' > /etc/yum.repos.d/local.repo
其他配置不变
4.保存自动应答文件
选择“Kickstart 配置程序”窗口的“文件”-->“保存”命令,选择指定保存位置,文件名为ks.cfg
默认保存在/root/ks.cfg
cp /root/ks.cfg /var/ftp/ks.cfg
5.配置需要安装的软件包
可以根据需要将/root/anaconda-ks.cfg 的软件包安装脚本复制到 ks.cfg文件中,只需要复制%packages 到%end 部分即可。
如要求最小化安装,可复制下面内容:
vim ks.cfg
%packages
@^minimal
%end
6.编辑引导菜单文件 default,添加 ks 引导参数
vim /var/lib/tftpboot/pxelinux.cfg/default
default auto
prompt 0 #设置是否等待用户选择,“0”表示不等待用户控制
label auto
kernel vmlinuz #kernel 和 append用来定义引导参数
append initrd=initrd.img method=ftp://20.0.0.111/centos7 ks=ftp://20.0.0.111/ks.cfg
#添加 ks 引导参数以指定 ks.cfg 应答文件的 URL 路径
7.验证无人值守安装
当客户机每次以PXE方式引导时,将自动下载ks.cfg应答配置文件,然后根据其中的设置安装CentOS 7 系统,而无须手工干预。
cat /etc/yum.repos.d/local.repo