文章目录
一、PXE原理和概念
PXE是由Intel 公司开发的网络引导技术,工作在 Client/Server模式,允许客户机通过网络从远程服务器下载引导镜像,并加载安装文件或者整个操作系统。
PXE严格来说并不是一种安装方式,而是一种引导的方式。进行PXE安装的必要条件是要安装的计算机中包含一个PXE支持的网卡(NIC),即网卡中必须要有PXE Client。PXE( Pre-boot Execution Environment)协议使计算机可以通过网络启动。
协议分为 Client 和 Server端,PXE client 在网卡的 ROM 中,当计算机引导时,BIOS 把PXE client 调入内存执行,由 PKE client 将放置在远端的文件通过网络下载到本地运行。运行 PXE协议需要设置。DHCP服务器和TFTP服务器。DHCP服务器用来给 PXE client(将要安装系统的主机)分配一个IP地址,由于是给PXE client分配IP地址,所以在配置DHCP 服务器时需要增加相应的PXE设置。
此外,在 PXE client 的 ROM中,已经存在了TFTP Client。PXE Client通过TFTP协议到TFTP Server 上下载所需的文件。
TFTP:69
优点:
规模化:同时装配多台服务器;
自动化:安装系统、配置各种服务;
远程实现:不需要光盘、U盘等安装介质。
前提条件:
客户机的网卡支持PXE协议(集成BOOTROM芯片),且主板支持网络引导。
网络中有一台DHCP服务器以便为客户机自动分配地址、指定引导文件位置。I服务器通过TFTP ( Trivial File Transfer Protocol,简单文件传输协议)提供引导镜像文件的下载。其中,第一个条件实际上是硬件要求,目前绝大多数服务器和大多数PC都能够提供此支持,只需在 BIOS 设置中允许从Network 或LAN启动即可。
二、KickStart概述
KickStart是一种无人职守安装方式。KickStart的工作原理是通过记录典型的安装过程中所需人工干预填写的各种参数,并生成一个名为ks.cfg 的文件;在其后的安装过程中(不只局限于生成Kickstart安装文件的机器)当出现要求填写参数的情况时,安装程序会首先去查找KickStart生成的文件,当找到合适的参数时,就采用找到的参数,当没有找到合适的参数时,才需要安装者手工干预。这样,如果KickStart文件涵盖了安装过程中出现的所有需要填写的参数时,安装者完全可以只告诉安装程序从何处取 ks.cfg文件,然后去忙自己的事情。等安装完毕,安装程序会根据ks.cfg 中设置的重启选项来重启系统,并结束安装。
三、PXE服务的构建过程
PXE服务器和客户机的工作过程:
1.PXE客户机发出DHCP请求,向DHCP服务器申请IP地址。
2.DHCP服务器响应PXE客户机的请求,自动从IP地址池中分配一个IP地址给PXE客户机,并且告知PXE客户机:TFTP服务器的IP地址和PXE引导程序文件pxelinux.0,默认在TFTP共享目录/var/lib/tftpboot/ 下
3.PXE客户机向TFTP服务器发起获取pxelinux.0引导程序文件的请求。
4.TFTP服务器响应PXE客户机的请求,将其共享的pxelinux.0文件传输给PxE客户机。
5.PXE客户机通过网络来启动到系统安装主界面。
6.PXE客户机向文件共享服务器(ftp、http、nfs等)发起获取centos或windows系统安装文件的请求。
7.文件共享服务响应PXE客户机的请求,将共享的系统安装文件传输给PXE客户机。
8.PXE客户机进入到安装提示向导界面,用户需要手动来完成系统安装的操作。
搭建工PXE远程安装服务器
所需安装包
vsftpd #用来放置安装镜像,通过ftp访问镜像安装
dhcp.x86_64 12:4.2.5-7pd-3.0.2-27.el7.x86_64.r9.el7.centos #用来给客户机分配ip
syslinux-4.05-15.el7.x86_64.rpm #用来提供pxe的引导程序
tftp-server.x86_64 0:5.2-22.el7.rpm #用来提供引导镜像文件的下载
xinetd.x86_64 2:2.3.15-14.el7 #用来托管tftp
system-config-kickstart.noarch 0:2.9.7-1.el7.rpm #用来无人值守安装
环境准备:
一台作为pxe服务器,一台作为裸金属客户机,绑定同一块网卡,裸金属客户机vmnet1网卡取消勾选dhcp配置
关闭selinux和防火墙
主机服务器地址: 192.168.10.13 主机名:KY17
一台主机:
(1)配置双网卡一个作用是dhcp,一个是使用网络源安装环境包
(2)DHCP部署
(3)tftp-server服务器通过TFTP ( Trivial File Transfer Protocol,简单文件传输协议)提供引导镜像文件的下载。
(4) syslinux #用来提供pxe的引导程序
(5) xinetd #用来托管tftp
(6)vsftpd1 #用来放置安装镜像,通过ftp访问镜像安装
(7) kickstart #用来无人值守安装
原理图
实验步骤
思路
1、安装并启用DHCP服务
yum -y install dhcp
cp -rfp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf
配置文件里做如下设置:
vim /etc/ dhcp/ dhcpd.conf
ddns-update-style none; #禁止动态更新
subnet 192.168.100.0 netmask 255.255.255.0 { //配置网段
range 192.168.100.40 192.168.100.50; //配置地址池
option routers 192.168.100.100; //配置网关
option domain-name-servers 114.114.114.114;
next-server 192.168.100.100; //指定tftp服务器的地址(* )
filename “pxelinux.0”; //指定pxe引导程序的文件名(* )
}
systemctl start dhcpd
systemctl enable dhcpd
当客户机访问dhcp是会根据里面的配置找到TFTP,并且进行访问。
访问网站必须要有DNS解析
2、安装并启用TFTP服务
TFTP:(Trivial File Transfer Protocol)是一个小而易于实现的文件传送协议。TFTP是基于UDP数据报,需要有自己的差错改正措施。TFTP只支持文件传输,不支持交互,没有庞大的命令集。也没有目录列表功能,以及不能对用户进行身份鉴别。但它的代码所占内存较小,不需要硬盘就可以固化TFTP代码,很适合较小的计算机和特殊用途的设备。
TFTP和FTP一个主要的区别就是它没有交互式,且不进行身份验证。
TFTP一般用于传输小文件
yum -y install tftp-server
vim /etc/xinetd.d/tftp #tftp被xinet所托管,xinetd默认没有安装,配置文件xinetd即extended internet
daemon,xinetd是新一代的网络守护进程服务程序,又叫超级Internet服务器。经常用来管理多种轻量Internet服务。xinetd提供类似于inetd+tcp_wrapper的功能,但是更加强大和安全。
3、
service tftp
{
socket_type =dgram
protocol =udp
wait =no # wait no表示客户机可以多台一起连接,yes表示客户机只能一台一台连接,表示是否开启多线程一起工作,否则需要等待
user =root
server =/usr/ sbin/in.tftpd
server_args =-s /var/lib/tftpboot #指定TFTP根目录(引导文件的存储路径)-c 允许上传
disable =no #disable no表示开启TFTP服务
per_source =11
#通过限制一个主机的最大连接数,从而防止某个主机独占某个服务,这里每个IP地址的连接数是11个
cps =100 2
#表示服务器最多启动100个连接,如果达到这个数目将停止启动新服务2秒。在此期间不接受任何请求
flags =IPv4
}
vmlinuz是可引导的、压缩的内核。"vm"代表"virtual Memory”。Linux支持虚拟内存,不像老的操作系统比如DOS有640KB内存的限制。Linux能够使用硬盘空间作为虚拟内存,因此得名"vm”。vmlinuz是可执行的Linux内核,它位于/boot/vmlinuz,它一般是一个软链接。
initrd是"initial ramdisk"的简写(系统初始化文件)。
initrd一般被用来临时的引导硬件到实际内核vmlinuz能够接管并继续引导的状态。initrd.img主要是用于加载ext4等文件系统及scsi设备的驱动。比如,使用的是scsi硬盘,而内核vmlinuz中并没有这个scsi硬件的驱动,那么在装入scsi模块之前,内核不能加载根文件系统,但scsi模块存储在根文件系统的/lib/modules下。为了解决这个问题,可以引导一个能够读实际内核的initrd内核并用initrd修正scsi引导问题。
#准备tftp 需要共享出去的文件
mount /dev/cdrom /mnt
cd /mnt/images/pxeboot/
#内核文件内核初始化镜像文件 /var/lib/tftpboot/站点
cp initrd.img vmlinuz /var/lib/tftpboot/
systemctl start xinetd
systemctl enable xinetd
systemctl start tftp
systemctl enable tftp
3、准备PXE 引导程序pxelinux.0
pxelinux.0是个二进制文件,主要作用相当于一个系统安装步骤的指引,引导客户端如何安装系统
yum provides * / pxelinux.0
#查找这个文件是由哪个软件包安装的,当不是一个路径和一个软件包时用* /
yum -y install syslinux
rpm -ql syslinux | grep pxelinux #查找pxe引导程序的位置
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
#拷贝到tftp的根目录下,系统引导文件
注:只有安装了system-config-kickstart软件包,才会有/usr/share/syslinux/目录及目录中的文件
4、配置启动菜单文件
启动菜单用来指导客户机的引导过程,包括如何调用内核,如何加载驱动。默认的启动菜单文件为default,应放置在 tftp根目录的pxelinux.cfg子目录下,典型的启动菜单配置可参考以下操作自动或手动建立。
至于为什么要是/var/lib/tftpboot/pxelinux.cfg/default文件,因为是由pxelinux.0这个文件决定好的
mkdir /var/lib/tftpboot/pxelinux.cfg
#默认pxelinux.cfg是没有的需要手动创建,注意它是一个目录而非文件虽然是以.cfg结尾以下为纯手工配置default菜单文件
vim /var/lib/tftpboot/pxelinux.cfg /default
default auto #指定默认入口名称,对应下面的label auto
prompt 1 #设置是否等待用户选择,1
label auto #默认的图形安装
Fernel vmlinuz
append initrd=initrd.img method=ftp://192.168.100.100/centos7
#method必须指定网络路径
label linux text #文本安装模式,出现boot:时输入linux text
kernel vmlinuz
append text initrd=initrd.img method=ftp://192.168.100.100/centos7
label linux rescue #救援模式,出现boot:时输入linux rescue
kernel vmlinuz
append rescue initrd=initrd.img method=ftp://192.168.100.100/centos7
表示等待用户控制,0表示不等待用户控制,安装时会出现boot:如果按回车表示选择auto模式
5、安装ftp服务,准备centos 7安装源yum -y install vsftpdI
mount / dev / cdrom /mnt
mkdir /var/ ftp/ centos7
cp -rf /mnt/* /var/ ftp/ centos7 #将镜像复制其中
systemctl start vsftpd
实验:
一、配置一块全新的网卡,并设置为vmnet1桥接模式
配置新网卡
重启网卡
二、配置DHCP地址池
-rfp:递归、强制、保留文件属性
配置dhcp参数
重启,开机自启dhcp服务
三、配置TFTP服务
xinetd:托管TFTP服务,是新一代的网络守护进程服务程序,又叫超级Internet服务器。经常用来管理多种轻量Internet服务
进行怪载
启动,开机自启动xinetd,tftp
tftp小服务通过端口查
四、配置启动菜单文件
五、安装ftp服务,准备 CentOS 7 安装源
这里已挂在不需要再次挂了
将镜像存放在/centos7中
启动vsftpd服务,关闭防火墙
增强关闭
六、Kickstart无人值守安装
创建一台虚拟机:必须大于2G,内核设为2个,vmnet1桥接模式
注意本地的vmnet1的地址不得与dhcp地址池中的默认网关地址相同,否则TFTP服务安装时会报超时的错误
出现boot按回车
在服务器中(192.168.193.160)安装system-config-kickstart工具
保存ks.cfg文件到文件系统------>var-------->ftp
进入/var/ftp/找到ks.cfg文件,并且将最小化加入到最后一行
%packages
@^graphical-server-environment
@base
@core
@desktop-debugging
@development
@dial-up
@fonts
@gnome-desktop
@guest-agents
@guest-desktop-agents
@hardware-monitoring
@input-methods
@internet-browser
@multimedia
@print-client
@x11
chrony
%end
这个是图形界面的参数
自动安装成功