一、PXE PXE(Pre-boot Execution Environment,预启动执行环境) 在Client/Server的网络模式下,通过网络从远端服务器下载映像,并通过网络启动操作系统。启动过程中,终端要求dhcp服务器分配IP地址,再用TFTP(trivial file transfer protocol)协议下载一个启动软件包到本机内存中执行,由这个启动软件包完成终端基本软件设置,从而引导预先安装在服务器中的终端操作系统。
二、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方式之一进行安装;
三、DHCP服务器
DHCP是一个基于UDP的工作在应用层的协议,用来自动分配IP地址。
提供的服务有:
1.提供IP地址和子网掩码
2.提供IP地址对应的网络地址和广播地址
3.默认网关地址
4.DNS服务器地址
租约时间:
DHCP分配给客户的IP是以租约形式分配的。当客户接入到网络中,DHCP便会分配一个IP给客户机,当租约时间到的时候如果客户机还在使用这个IP那么就可以续约,继续使用当前IP而不是从新分配一个。
安装DHCP服务器
# yum -y install dhcpd
配置DHCP服务
# vim /etc/dhcp/dhcpd.conf
ddns-update-style interim;#设置DHCP于DNS服务器的动态信息更新模式。初学时完全可以不理这个选项,但是全局设置中一定要有这个选项,否则DHCP服务不能成功启动。
ignore client-updates; #忽略客户端更新
option domain-name-servers 114.114.114.114, 8.8.8.8; #设置DNS服务器地址#下面开始分配子网,网段是172.16.0.0 子网掩码是 255.255.0.0#不能理解网段和子网掩码的可以去网上查一下。简单的说网段规定了分配IP的段(分配哪一段IP给客户机),子网掩码规定了网段的大小
subnet 172.16.0.0 netmask 255.255.0.0 {#range 172.16.5.212 192.168.5.215; #分配给客户机的IP从172.16.5.212开始到 172.16.5.215
option broadcast-address 172.16.255.255; #广播地址
option routers 172.16.1.1; #设置网关 default-lease-time 600; #默认租约时间
max-lease-time 7200; #最大租约时间 next-server 172.16.5.135; #dhcp ip地址
filename "pxelinux.0"; #PXE文件
}
host centos7 { #主机名为centos7
hardware ethernet 08:00:27:5e:04:27; #MAC地址是08:...:27的网卡
fixed-address 172.16.5.136; #分配给它172.16.5.136的IP
}# 只要这个CLient_C接入到了这个网络中,那么它获取的IP就是固定的这一个,并不会变
重启DHCP服务
# systemctl restart dhcpd.service
四、TFTP服务器 TFTP(Trivial File Transfer Protocol,简单文件传输协议)是TCP/IP协议族中的一个用来在客户机与服务器之间 进行简单文件传输的协议,提供不复杂、开销不大的文件传输服务。端口号为UDP的69号端口。
安装tftp-server 、xinetd
#yum –y install tftp-server xinetd
启用TFTP服务, vi /etc/xinetd.d/tftp
将disable 设置为no 启动TFTP服务,systemctl start xinetd
五、HTTP服务 HTTP协议定义Web客户端如何从Web服务器请求Web页面,以及服务器如何把Web页面传送给客户端。HTTP协议采用了请求/响应模型。 1、安装软件: yum -y install httpd 2、启动服务:systemctl start httpd 3、设置开机启动: systemctl enable httpd
将iso文件挂载至/var/www/html/os/
# mount -t iso9660 -o loop /image/os/CentOS-7-x86_64-DVD-1611.iso /var/www/html/os
六、配置支持PXE的启动程序 获取pxelinux.0 文件
# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
复制iso 镜像中的/image/pxeboot/initrd.img 和vmlinux 至/var/lib/tftpboot/ 文件夹中
# cp /var/www/html/os/images/pxeboot/{initrd.img,vmlinuz} /var/lib/tftpboot/
复制iso 镜像中的/isolinux/.msg 至/var/lib/tftpboot/ 文件夹中
# cp /var/www/html/cdrom/isolinux/
.msg /var/lib/tftpboot/
复制vesamenu.32c的作用就是启动菜单外观绘制拓展工具
# cp /cgls/vesamenu.32c /var/lib/tftpboot/
在/var/lib/tftpboot/ 中新建一个pxelinux.cfg目录
# mkdir /var/lib/tftpboot/pxelinux.cfg
将iso 镜像中的/isolinux 目录中的isolinux.cfg复制到pxelinux.cfg目录中,同时更改文件名称为default
# cp /var/www/html/cdrom/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
修改default文件
# vi /var/lib/tftpboot/pxelinux.cfg/default
default vesamenu.c32 #引入菜单外观绘制拓展工具
prompt 0
timeout 100
display boot.msg
menu clear #菜单颜色
menu background splash.png
menu title CentOS 7
menu vshift 8
menu rows 18
menu margin 8
menu helpmsgrow 15
menu tabmsgrow 13
menu color border * #00000000 #00000000 none
menu color sel 0 #ffffffff #00000000 none
menu color title 0 #ff7ba3d0 #00000000 none
menu color tabmsg 0 #ff3a6496 #00000000 none
menu color tabmsg 0 #ff3a6496 #00000000 none
menu color hotsel 0 #84b8ffff #00000000 none
menu color hotkey 0 #ffffffff #00000000 none
menu color help 0 #ffffffff #00000000 none
menu color scrollbar 0 #ffffffff #ff355594 none
menu color scrollbar 0 #ffffffff #ff355594 none
menu color cmdmark 0 #84b8ffff #00000000 none
menu color cmdline 0 #ffffffff #00000000 none
menu tabmsg Press Tab for full configuration options on menu items.
menu separator # insert an empty line
menu separator # insert an empty line
label linux #菜单选项
menu label ^Install CentOS 7
kernel vmlinuz
append initrd=initrd.img inst.repo=http://172.16.5.135/os/ net.ifnames=0 biosdevname=0
label ks
menu label ^Auto Install CentOS 7
menu default
kernel vmlinuz
append ks=http://172.16.5.135/ks.cfg initrd=initrd.img net.ifnames=0 biosdevname=0
menu separator # insert an empty line
七、编写ks.cfg
#vi /var/www/html/ks.cfg
version=RHEL7
System authorization information
auth --enableshadow --passalgo=sha512
Install OS instead of upgrade
install
Reboot after installation
reboot
Use network installation
url --url=http://172.16.5.135/os/ ##这个选项告诉安装程序:到服务器192.168.111.130 的HTTP根目录下的cdrom 文件夹下寻找安装介质
Use graphical install
graphical
Firewall configuration
firewall --enabled --port=22:tcp
Keyboard layouts
keyboard --vckeymap=us --xlayouts='us'
System language
lang en_US.UTF-8
Network information
%include /tmp/network
Root password
rootpw 123qwe
rootpw --iscrypted $6$CD2GJykfp0S72QWl$mF26Q1QMkg1QubquxOTulUKJ6MhhXPuJ8xNU0nWM0HU2Wd/BItPOKY6BdOo03IX9umtykJuRKEiy2yf51dOuQ1
SELinux configuration
selinux --disabled
System timezone
timezone Asia/Shanghai --isUtc
System bootloader configuration
Partition clearing information
Clear the Master Boot Record
Disk partitioning information
%include /tmp/disk
%pre --logfile /tmp/ks-pre.log
!/bin/sh
Disk partitioning
declare -a disks
echo "clearpart --all" > /tmp/disk
echo "clearpart --none" > /tmp/disk
echo "zerombr" >> /tmp/disk
disks=(fdisk -l | grep "^Disk /dev/[s,h,v]d" | awk -F ' |:' '{print $2}'
)
disks=(echo ${disks[@]} | xargs -n 1 | sort -k 1.8
)
len=${#disks[@]}
diskstr=""
for ((i=0;i<$len;i++))
do
parted -s ${disks[$i]} mklabel gpt
partprobe ${disks[$i]}
dev=basename ${disks[$i]}
if [ $i -eq 0 ]; then
echo "part biosboot --fstype=biosboot --ondisk=$dev --size=1" >> /tmp/disk
echo "part /boot --fstype=xfs --ondisk=$dev --size=300" >> /tmp/disk
echo "part swap --fstype=swap --ondisk=$dev --recommended" >> /tmp/disk
echo "part / --fstype=xfs --ondisk=$dev --size=204800" >> /tmp/disk
echo "part / --fstype=xfs --ondisk=$dev --grow" >> /tmp/disk
echo "bootloader --location=mbr --boot-drive=$dev" >> /tmp/disk
diskstr=$dev
else
echo "part /disk$i --fstype=xfs --ondisk=$dev --grow" >> /tmp/disk
diskstr=$diskstr,$dev
fi
done
echo "ignoredisk --only-use=$diskstr" >> /tmp/disk
Network configuration
declare -a nics
nicstr=grep : /proc/net/dev | awk -F : '{print $1}'
nics=(${nicstr/lo/})
/tmp/network
len=${#nics[@]}
for ((i=0;i<$len;i++))
do
nic=${nics[$i]}
echo "network --bootproto=dhcp --device=$nic --onboot=on --ipv6=auto" >> /tmp/network
done
%end
%packages
@^infrastructure-server-environment
@base
@core
kexec-tools
%end
%addon com_redhat_kdump --enable --reserve-mb='auto'
%end
重启所有服务
# systemctl restart xinetd
# systemctl restart httpd
# systemctl restart dhcpd