文章目录
引言:
在生产环境中,安装大量服务器时,人工安装太过耗时。
基于 PXE(Preboot eXecution Environment,预启动执行环境)技术的网络装机方法,并结合 Kickstart 配置实现无人值守自动安装。
一.概述
1.1PXE原理
PXE 是由 Intel 公司开发的网络引导技术,工作在 Client/Server 模式,允许客户机通过网络从远程服务器下载引导镜像,并加载安装文件或者整个操作系统。
客户机的网卡支持 PXE 协议(集成 BOOTROM 芯片),且主板支持网络引导。
网络中有一台 DHCP 服务器以便为客户机自动分配地址、指定引导文件位置。
服务器通过 TFTP(Trivial File Transfer Protocol,简单文件传输协议)提供引导镜像文件的下载。
1.2kickstart原理
KickStart 是一种无人职守安装方式。
KickStart 的工作原理是通过记录典型的安装过程中所需人工干预填写的各种参数,并生成一个名为 ks.cfg 的文件;在其后的安装过程中,当出现要求填写参数的情况时,安装程序会首先去查找 KickStart 生成的文件,当找到合适的参数时,就采用找到的参数,当没有找到合适的参数时,才需要安装者手工干预。这样,如果 KickStart 文件涵盖了安装过程中出现的所有需要填写的参数时,安装者完全可以只告诉安装程序从何处取 ks.cfg 文件。等安装完毕,安装程序会根据 ks.cfg 中设置的重启选项来重启系统,并结束安装。
二.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
2.1DHCP服务配置
1.检查并安装DHCP服务
rpm -q dhcp
yum install -y dhcp
2.拷贝默认配置文件
因为etc下的dhcp.conf文件内容为空
cp -rfp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf
3.编辑配置文件
vim /etc/dhcp/dhcpd.conf
subnet 192.168.100.0 netmask 255.255.255.0 { //配置网段
range 192.168.100.100 192.168.100.200; //配置地址池
option domain-name-servers 114.114.114.114; //设置DNS
option routers 192.168.100.1; //设置网关
next-servers 192.168.100.1; //指定tftp服务器地址
filename "pxelinux.0"; //指定pxe引导程序的文件名
}
4.新添加网卡
配置新增的网卡:
[root@xiayan ~]# cd /etc/sysconfig/network-scripts/
[root@xiayan network-scripts]# cp ifcfg-ens33 ifcfg-ens36
[root@xiayan network-scripts]# vim ifcfg-ens36
5.重启服务
systemctl restart network #重启网络服务
systemctl start dhcpd #启动dhcp服务
systemctl enable dhcpd #设置开机自启
2.2TFTP服务配置
TFTP是一个小而易于实现的文件传送协议。TFTP是基于UDP数据报,需要有自己的差错改正措施。TFTP只支持文件传输,不支持交互,没有庞大的命令集。也没有目录列表功能,以及不能对用户进行身份鉴别。但它的代码所占内存较小,不需要硬盘就可以固化TFTP代码,很适合较小的计算机和特殊用途的设备。
tftp被xinet所托管,xinetd是新一代的网络守护进程服务程序,又叫超级Internet服务器。经常用来管理多种轻量级Internet服务。xinetd提供类似于inetd+tcp_wrapper的功能,但是更加强大和安全。
所以安装TFTP时也需要安装xinetd服务
1.检查并安装服务
root@xiayan ~]# rpm -q tftp-server
package tftp-server is not installed
[root@xiayan ~]# yum install -y tftp-server
[root@xiayan ~]# rpm -q xinetd
package xinetd is not installed
[root@xiayan ~]# yum install -y xinetd
2.TFTP服务配置
vim /etc/xinetd.d/tftp TFTP服务的配置文件位于该位置
service tftp
{
socket_type = dgram
protocol = udp
wait = no //no表示客户机可以多台一起连接,yes只能一台一台连接
user = root
server = /usr/sbin/in.tftpd
server_args = -s /var/lib/tftpboot //指定TFTP根目录(引导文件的存储路径)-s下载-c上传
disable = no //disable no表示开启TFTP服务
per_source = 11 //限制一个主机的最大连接数,每个IP地址的连接数是11个
cps = 100 2 //表示服务器最多启动100个连接,如果达到这个数目将停止启动新服务2秒。
flags = IPv4 //网络类型
}
3.创建共享文件
用于 PXE 网络安装的 Linux 内核、驱动文件可以从 CentOS 7 系统光盘获得, 分别为vmlinuz 和 initrd.img,位于光盘目录 images/pxeboot 下。找到这两个文件并将其复制到 tftp 服务的根目录下。
vmlinuz是可引导的、压缩的内核。vmlinuz是可执行的Linux内核,它位于/boot/vmlinuz,它一般是一个软链接。
initrd是“initial ramdisk”的简写(系统初始化文件)。initrd一般被用来临时的引导硬件到实际内核vmlinuz能够接管并继续引导的状态。initrd.img主要是用于加载ext4等文件系统及scsi设备的驱动。
[root@xiayan ~]# mount /dev/cdrom /mnt #挂载镜像文件
[root@xiayan ~]# cd /mnt/images/pxeboot/
[root@xiayan pxeboot]# ls
initrd.img TRANS.TBL vmlinuz
[root@xiayan pxeboot]# cp initrd.img vmlinuz /var/lib/tftpboot/ #将文件复制到tftp根目录下
4.重启服务
systemctl start xinetd
systemctl enable xinetd
systemctl start tftp
systemctl enable tftp
2.3PXE引导程序配置
PXE引导程序pxelinux.0
pxelinux.0是个二进制文件,主要作用相当于一个系统安装步骤的指引,引导客户端如何安装系统
yum provides */pxelinux.0 查找这个文件是由哪个软件包安装的
1.安装程序
[root@xiayan ~]# yum provides */pxelinux.0 查找这个文件是由哪个软件包安装的
[root@xiayan ~]# yum install -y syslinux
[root@xiayan ~]# rpm -ql syslinux | grep pxelinux #查找pxe引导程序的位置
[root@xiayan ~]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot #拷贝到tftp的根目录下,系统引导文件
2.4FTP服务配置
1.安装FTP服务
[root@xiayan ~]# rpm -q vsftpd
package vsftpd is not installed
[root@xiayan ~]# yum install -y vsftpd
[root@xiayan ~]# mount /dev/cdrom /mnt #挂载镜像文件
[root@xiayan ~]# mkdir /var/ftp/centos7
[root@xiayan ~]# cp -rf /mnt/* /var/ftp/centos7/ & #后台复制镜像文件到ftp下
[1] 16544
[root@xiayan ~]# systemctl start vsftpd
2.重启服务
[root@xiayan ~]# systemctl start vsftpd
[root@xiayan ~]# systemctl enable vsftpd
2.5启动菜单文件配置
启动菜单用来指导客户机的引导过程,包括如何调用内核,如何加载驱动。默认的启动菜单文件为 default,应放置在 tftp 根目录的 pxelinux.cfg 子目录下。注意 pxelinux.cfg是一个目录而非.cfg的文件。
所以启动菜单文件位置为:/var/lib/tftpboot/pxelinux.cfg/default
[root@xiayan ~]# mkdir /var/lib/tftpboot/pxelinux.cfg #创建pxelinux.cfg目录
[root@xiayan ~]# vim /var/lib/tftpboot/pxelinux.cfg/default
default auto //指定默认入口名称 ,对应下面的label auto
prompt 0 //设置是否等待用户选择,1 表示等待用户控制,0表示不等待用户控制,安装时会出现boot:如果按回车表示选择auto模式
label auto //默认的图形安装
kernel vmlinuz
append initrd=initrd.img method=ftp://192.168.100.1/centos7 //method必须指定网络路
label linux text //文本安装模式,出现boot:时输入linux text
kernel vmlinuz
append text initrd=initrd.img method=ftp://192.168.100.1/centos7
label linux rescue //救援模式,出现boot:时输入linux rescue
kernel vmlinuz
append rescue initrd=initrd.img method=ftp://192.168.100.1/centos7
三.kickstart无人值守
所需安装包:
system-config-kickstart.noarch 0:2.9.7-1.el7.rpm
1.检查并安装程序
[root@xiayan ~]# rpm -q system-config-kickstart
package system-config-kickstart is not installed
[root@xiayan ~]# yum install -y system-config-kickstart
2.打开"Kickstart配置程序”窗口
通过桌面菜单"应用程序"–>“系统工具”–>"Kickstart”打开或执行"system-config-kickstart”命令打开
3.配置kickstart选项
默认语言设为 英文或中文(简体)
时区设为 Asia/Shanghai
设置root密码
高级配置中勾选 安装后重启
安装方法选择 FTP
FTP服务器 ftp://192.168.100.1
FTP目录 centos7
引导装载程序选项:安装新引导装载程序
主引导记录:清除主引导记录
分区:删除所有现存分区
磁盘标签:初始化磁盘标签
添加分区:正常分区(需求)
添加网络设备 ens33
网络类型设为 DHCP
验证:无需操作
防火墙:禁用
4.编辑ks.cfg
vim /var/ftp/ks.cfg
添加途中内容,可以查看本机配置,将图中内容复制到ks.cfg中
5.添加 ks 引导参数至引导菜单文件
vim /var/lib/tftpboot/pxelinux.cfg/default
四.PXE无人值守安装
新建虚拟机,将网卡改为vm1,开启虚拟机后,系统将自动进行安装,无需任人工操作