首页 > 代码库 > PXE+Kickstart
PXE+Kickstart
PXE 预启动执行环境(Preboot eXecution Environment,也被称为预执行环境)提供了一种使用网络接口(Network Interface)启动计算机的机制。这种机制让计算机的启动可以不依赖本地数据存储设备(如硬盘)或本地已安装的操作系统。网卡中必须要有 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 工作流程:
1. PXE Client 从自己的PXE网卡启动,向本网络中的DHCP服务器索取IP;
2. DHCP 服务器返回分配给客户机的IP 以及PXE文件的放置位置(该文件一般是放在一台TFTP服务器上) ;
3. PXE Client 向本网络中的TFTP服务器索取pxelinux.0 文件;
4. PXE Client 取得pxelinux.0 文件后之执行该文件;
5. 根据pxelinux.0 的执行结果,通过TFTP服务器加载内核和文件系统 ;
6. 进入安装画面, 此时可以通过选择HTTP、FTP、NFS 方式之一进行安装;
pxe
Kickstart是一种无人值守的安装方式。它的工作原理是在安装过程中记录典型的需要人工干预填写的各种参数,并生成一个名为ks.cfg的文件。如果在安装过程中(不只局限于生成Kickstart安装文件的机器)出现要填写参数的情况,安装程序首先会去查找Kickstart生成的文件,如果找到合适的参数,就采用所找到的参数;如果没有找到合适的参数,便需要安装者手工干预了。所以,如果Kickstart文件涵盖了安装过程中可能出现的所有需要填写的参数,那么安装者完全可以只告诉安装程序从何处取ks.cfg文件,然后就去忙自己的事情。等安装完毕,安装程序会根据ks.cfg中的设置重启系统,并结束安装。
kickstart
约定:
要批量安装的系统为 CentOS-6.6-x86_64
要批量安装系统的服务器跟 Server 在同一 VLAN 内(接同一交换机。暂不考虑,大规模跨VLAN的部署。)
Server 开启 DHCP TFTP HTTP 服务
Server 端的IP为 10.0.1.254;DHCP 为客户端分配的IP范围为 10.0.1.2 – 10.0.1.253
部署服务端:
[root@linux-boy ~]# ifconfig eth1|awk -F "[ :]+" ‘NR==2{print $4}‘
10.0.1.254
[root@linux-boy ~]#
安装 dhcp tftp-server httpd 及包含 pxelinu.0 引导文件的 syslinux
[root@linux-boy ~]# yum -q -y install dhcp tftp-server httpd syslinux
[root@linux-boy ~]# rpm -qa dhcp tftp httpd-server syslinux
tftp-server-0.49-7.el6.x86_64
syslinux-4.04-3.el6.x86_64
dhcp-4.1.1-49.P1.el6.centos.x86_64
httpd-2.2.15-47.el6.centos.x86_64
[root@linux-boy ~]#
编辑 DHCP 配置文件,并启动服务。
[root@linux-boy ~]# cat /etc/dhcp/dhcpd.conf
ddns-update-style none;
ignore client-updates;
subnet 10.0.1.0 netmask 255.255.255.0 {
range 10.0.1.2 10.0.1.253;
option subnet-mask 255.255.255.0;
next-server 10.0.1.254;
filename "pxelinux.0";
default-lease-time 21600;
max-lease-time 43200;
}
[root@linux-boy ~]#
[root@linux-boy ~]# /etc/init.d/dhcpd start
Starting dhcpd: [ OK ]
[root@linux-boy ~]#
为 Apache 的默认配置文件第277行加入 ServerName 0.0.0.0:80 并在默认的站点目录下新建目录并将本地光驱中的 CentOS-6.6-x86_64-bin-DVD1 挂载至新建目录下。开启服务。
[root@linux-boy ~]# sed -i ‘277i ServerName 0.0.0.0:80‘ /etc/httpd/conf/httpd.conf
[root@linux-boy ~]# mkdir /var/www/html/centos66
[root@linux-boy ~]# mount /dev/cdrom /var/www/html/centos66/
mount: block device /dev/sr0 is write-protected, mounting read-only
[root@linux-boy ~]# ls /var/www/html/centos66
CentOS_BuildTag RELEASE-NOTES-en-US.html
EFI repodata
EULA RPM-GPG-KEY-CentOS-6
GPL RPM-GPG-KEY-CentOS-Debug-6
images RPM-GPG-KEY-CentOS-Security-6
isolinux RPM-GPG-KEY-CentOS-Testing-6
Packages TRANS.TBL
[root@linux-boy ~]#
[root@linux-boy ~]# /etc/init.d/httpd start
Starting httpd: [ OK ]
[root@linux-boy ~]#
将需要的 pxelinux.0 文件,及挂载镜像目录中的 isolinux 目录下的所有文件(并不需要所有的文件,为简化操作复制所有文件即可)复制到 TFTP 提供服务的根目录。
[root@linux-boy ~]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
[root@linux-boy ~]# cp /var/www/html/centos66/isolinux/* /var/lib/tftpboot/
[root@linux-boy ~]# ls /var/lib/tftpboot/
boot.cat initrd.img memtest TRANS.TBL
boot.msg isolinux.bin pxelinux.0 vesamenu.c32
grub.conf isolinux.cfg splash.jpg vmlinuz
[root@linux-boy ~]#
在 TFTP 提供服务的根目录下,新建名为 pxelinux.cfg 的目录,并在新建的 pxelinux.cfg 目录下新建名为 defualt 的文件。
[root@linux-boy ~]# mkdir /var/lib/tftpboot/pxelinux.cfg
[root@linux-boy ~]# cat /var/lib/tftpboot/pxelinux.cfg/default
default ks
prompt 0
label ks
kernel vmlinuz
append initrd=initrd.img ks=http://10.0.1.254/ks.cfg ksdevice=eth0
[root@linux-boy ~]#
修改 TFTP 的配置文件,并开启服务。
[root@linux-boy ~]# sed -i ‘14 s#yes#no#‘ /etc/xinetd.d/tftp
[root@linux-boy ~]#
[root@linux-boy ~]# /etc/init.d/xinetd restart
Stopping xinetd: [FAILED]
Starting xinetd: [ OK ]
[root@linux-boy ~]#
使用 grub-crypt 命令,生成新装系统 root 用户的密码。记录下生成的密码。
[root@linux-boy ~]# grub-crypt
Password:
Retype password:
$6$dc4hJJe7NhUbVtzn$///p3CWjPJKI7dDNvHG69ank0njFu3.xIYLmBgMB.UzmZOG2FA741uIf1rYyWUf/LTL9FVk3u8.tL2YkekxMZ0
[root@linux-boy ~]#
编写 kickstart 文件。并将文件命名为 ks.cfg 保存在 Apache 默认的站点目录下。(注意文件权限,确保可以访问。)
[root@linux-boy ~]# cat /var/www/html/ks.cfg
install
text
url --url http://10.0.1.254/centos66
lang en_US.UTF-8
keyboard us
network --onboot yes --device eth0 --bootproto dhcp --noipv6
rootpw --iscrypted $6$dc4hJJe7NhUbVtzn$///p3CWjPJKI7dDNvHG69ank0njFu3.xIYLmBgMB.UzmZOG2FA741uIf1rYyWUf/LTL9FVk3u8.tL2YkekxMZ0
firewall --disabled
authconfig --enableshadow --passalgo=sha512
selinux --disabled
timezone Asia/Shanghai
zerombr
bootloader --location=mbr --driveorder=sda --append="crashkernel=auto rhgb quiet"
clearpart --all --initlabel
part /boot --fstype=ext4 --asprimary --size=200
part swap --asprimary --size=1024
part / --fstype=ext4 --grow --asprimary --size=200
reboot
%packages
@base
@compat-libraries
@debugging
@development
tree
nmap
sysstat
lrzsz
dos2unix
telnet
#%post
# before installed run some command or scripts
%end
[root@linux-boy ~]#
开启客户端电源,系统会自动安装。
PXE+Kickstart