PXE(preboot execute environment预启动执行环境 ),支持Client通过网络从Server下载映像,并由此支持通过网络启动操作系统,在启动过程中,Client要求Server分配IP地址,再用TFTP(trivial file transfer protocol)或MTFTP(multicast trivial file transfer protocol)协议下载一个启动软件包到Client内存中执行,由这个启动软件包完成Client上的基本软件设置,从而引导预先安装在Sserver上的操作系统,即”推机”。本篇介绍在RHEL7上的PXE服务器搭建。
1、Client首先要获取 IP(进行网络连接):
PXEserver中要含有DHCPservice,为Client提供p-netmask-gw-dns。
2、Client想要得到安装界面,PXEserver必须为其提供系统引导:
Client从PXEserver中获得 pxelinux.0(实际上就是 grub)、vmlinuz(内核文件),initrd(内存驱动盘)这3个文件。先通过引导 grub,再加载其余2个文件来实现Client的系统引导。
3、通过TFTPserver以广播的形式发送系统引导所需要的3个文件给Client:
PXEserver告知TFTPserver Client的IP,再由TFTPserver将系统引导的3个文件发送给Client。
4、TFTPserver共享Client安装系统所需要的软件包:
通过FTP(RHEL6)、HTTP(RHEL7)、 nfs(RHEL5)等服务实现C\S之间的文件共享。
4、安装系统时设置Hostname :如果没有设置Client的hostname,默认为localhost.localdomain。若想给每个Client都设置唯一的hostname,需要DNSserver,再利用DNSserver的反向解析,为Client分配Hostname。
5、批量部署:使用 Kickstart无人值守服务批量部署服务器。
总结:PXE服务器需要提供下列服务
(1)DHCP
(2)TFTP
(3)FTP|HTTP|NFS
(4)DNS
(5)Kickstart
下面几种不同OS平台上的部署方案均使用了Kickstart无人值守服务:
1)Sattlle
2)RH401 卫星服务器(walkspace centos)
3)windows WDS
本篇的实验是搭建all-in-one的PXE服务器,即将上述所有的服务搭建在用一台服务器上。
setenforce 0
systemctl stop firewalld.service
systemctl mask iptables.service
systemctl mask ebtables.service
安装DHCP软件包:
yum install dhcp
编辑DHCP服务配置文件:
Copy模版得到配置文件
cat /usr/share/doc/dhcp*/dhcpd.conf.example > /etc/dhcp/dhcpd.conf
vim /etc/dhcp/dhcpd.conf
log-facility local7;
subnet 192.168.0.0 netmask 255.255.255.0 {
range 192.168.0.10 192.168.0.100;
option domain-name-servers 192.168.0.1;
option domain-name "fan.com";
option routers 192.168.0.1;
next-server 192.168.0.1; #指定TFTPserver ip,现在为本机IP
filename "/pxelinux.0"; #此"/"指的是TFTP共享的根目录/var/lib/tftpboot下
option broadcast-address 192.168.0.255;
default-lease-time 600;
max-lease-time 7200;
}
重启DHCP服务加载配置:
systemctl restart dhcpd
netstat -anplut |grep dhcp
systemctl enable dhcpd.service
安装TFTP软件包:
yum install tftp-server
安装syslinux软件包:
获取pxelinux.0文件
cd /var/lib/tftpboot #TFTP共享跟目录
yum install syslinux
rpm -ql syslinux | grep pxelinux.0 #查询软件包文件的安装位置
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot
从OS光盘中获取initrd.img、vmlinuz文件:
mount /dev/cdrom /mnt/cdrom
cd /mnt/cdrom/images/pxeboot
cp initrd.img vmlinuz /var/lib/tftpboot
获取pxelinux的配置文件:
在推机的过程中,Pxelinux会以IP地址的16进制表示来搜索配置文件,如果没找到,就去除最低一位数后继续找。如果所有匹配都失败,就使用default文件。
mkdir /var/lib/tftpboot/pxelinux.cfg
cp /mnt/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
chmod u+w /var/lib/tftpboot/pxelinux.cfg/default
cp /mnt/isolinux/boot.msg /var/lib/tftpboot/ #引导图片
chmod u+w /var/lib/tftpboot/boot.msg
编辑pxelinux的配置文件:
vim /var/lib/tftpboot/pxelinux.cfg/default
default linux #第一个label改为linux
append #扩充无人值守功能
initrd=initrd.img inst.repo=ftp://192.168.0.1/cdrom ks=ftp://192.168.0.1/ks.cfg quiet #指定无人值守文件ks.cfg
编辑TFTP服务配置文件:
vim /etc/xinetd.d/tftp
disable=no
重启TFTP :
systemctl restart xinetd.service
netstat -anplut | grep :69 #检查xinetd服务是否启动
将OS光盘中的软件包共享给Client。
安装vsftpd软件包:
yum install vsftpd
挂载光盘到FTP跟目录下:
mkdir /var/ftp/cdrom
mount /dev/cdrom /var/ftp/cdrom
重启FTP服务
systemctl restart vsftpd
systemctl enable vsftpd
使用用图形化界面system-config-kickstart 建立自动应答Kickstart文件。
安装图形化界面:
yum install system-config-kickstart
再次编辑Kickstart无人值守文件:
vim /root/ks.cfg
加入你未来部署系统的软件包(%packages 软件包名 %end)
通过FTP服务共享ks.cfg文件
cp /root/ks.cfg /var/ftp
systemctl restart xinetd.service
Jmilk