PXE真正完成批量自动安装
- 前言:
- 一、PXE的概念及原理
- 二. KickStart 概述
- 三. PXE服务的构建过程及所需安装包
- 四. 环境准备:
-
- 4.1具体步骤如下:
-
- 4.1.1 添加一块新网卡并配置**
- 4.1.2 安装TFTP服务
- 4.1.3修改TFTP服务的配置文件,并开启服务
- 4.1.4安装DHCP服务
- 4.1.5修改DHCP服务的配置文件并开启服务
- 4.1.6 准备Linux内核、初始化镜像文件
- 4.1.7准备PXE引导程序
- 4.1.8安装FTP服务,准备CentOS 7 安装源
- 4.1.9配置启动菜单文件(默认文件名为default,位于TFTP根目录的pxelinux.cfg子目录下)
- 4.1.10关闭防火墙,验证PXE网络安装
- 五. 实现Kickstart无人值守安装
- 六、总结
前言:
对与运维人员来说,如何安装操作系统简直就是轻而易举;但当我们面对大量需要安装系统的环境时,自动化安装系统就成了一项必备的技能;接下来就跟着小编一起来用PXE批量安装操作系统吧!
一、PXE的概念及原理
1.1 pxe概念
PXE(预启动执行环境)是由Inter公司开发的网络引导技术,工作在Client/Server模式,允许客户机通过网络从远程服务器下载引导镜像,并加载安装文件或整个操作系统。
1.2 pxe原理
PXE 严格来说并不是一种安装方式,而是一种引导的方式。进行 PXE 安装的必要条件
是要安装的计算机中包含一个 PXE 支持的网卡(NIC)
,即网卡中必须要有 PXE Client。PXE (Pre-boot Execution Environment)协议使计算机可以通过网络启动。协议分为 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。PXE Client 通过 TFTP 协议【端口69】到 TFTP Server 上下载所需的文件。
1.3PXE批量部署的优点
-
1、规模化:同时装配多台服务器
-
2、自动化:安装系统、配置各种服务
-
3、远程实现:不需要光盘、U盘等安装介质
1.4搭建PXE的必要条件
前提条件:
- 客户机的网卡支持 PXE 协议(集成 BOOTROM 芯片),且主板支持网络引导。
- 网络中有一台 DHCP 服务器以便为客户机自动分配地址、指定引导文件位置。
- 服务器通过 TFTP(Trivial File Transfer Protocol,简单文件传输协议)提供引导镜像文件的下载。
其中,第一个条件实际上是硬件要求,目前绝大多数服务器和大多数 PC 都能够提供此支持,只需在 BIOS 设置中允许从 Network 或LAN 启动即可。
二. KickStart 概述
KickStart 是一种无人职守安装方式
。KickStart 的工作原理是
通过记录典型的安装过程中所需人工干预填写的各种参数,并生成一个名为 ks.cfg 的文件;在其后的安装过程中(不只局限于生成 KickStart 安装文件的机器)当出现要求填写参数的情况时,安装程序会首先去查找 KickStart 生成的文件,当找到合适的参数时,就采用找到的参数,当没有找到合适的参数时,才需要安装者手工干预。
这样,如果 KickStart 文件涵盖了安装过程中出现的所有需要填写的参数时,安装者完全可以只告诉安装程序从何处取 ks.cfg 文件,然后去忙自己的事情。等安装完毕,安装程序会根据 ks.cfg 中设置的重启选项来重启系统,并结束安装。
三. PXE服务的构建过程及所需安装包
1.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客户机进入到安装提示向导界面,用户需要手动来完成系统安装的操作
2.搭建 PXE 远程安装服务器所需安装包:
1.vsftpd //用来放置安装镜像,通过ftp访问镜像安装
2.dhcp.x86_64 12:4.2.5-7pd-3.0.2-27.el7.x86_64.r9.el7.centos //用来给客户机分配ip
3.syslinux-4.05-15.el7.x86_64.rpm //用来提供pxe的引导程序
4.tftp-server.x86_64 0:5.2-22.el7.rpm //用来提供引导镜像文件的下载
5.xinetd.x86_64 2:2.3.15-14.el7 //用来托管tftp
6.system-config-kickstart.noarch 0:2.9.7-1.el7.rpm //用来无人值守安装
四. 环境准备:
一台作为pxe服务器,一台作为裸金属客户机,绑定同一块网卡,裸金属客户机vmnet1网卡取消勾选dhcp配置
关闭selinux和防火墙
主机服务器地址:192.168.10.12 主机名:KY19
一台主机:
1)配置`双网卡` 一个作用是dhcp,一个是使用网络源安装环境包
2)DHCP部署
3)tftp-server 服务器通过 TFTP(Trivial File Transfer Protocol,简单文件传输协议)提供引导镜像文件的下载。
4)syslinux //用来提供pxe的引导程序
5)xinetd //用来托管tftp
6)vsftpd //用来放置安装镜像,通过ftp访问镜像安装
7)kickstart //用来无人值守安装
4.1具体步骤如下:
4.1.1 添加一块新网卡并配置**
4.1.1.1新建网卡
4.1.1.2查看vmware1的网段
4.1.1.3 复制网卡并编辑
4.1.1.4重启网卡并查看
4.1.2 安装TFTP服务
4.1.3修改TFTP服务的配置文件,并开启服务
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
}
4.1.4安装DHCP服务
4.1.5修改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
4.1.6 准备Linux内核、初始化镜像文件
#准备 tftp 需要共享出去的文件
mount /dev/sr0 /mnt
cd /mnt/images/pxeboot/
#内核文件 内核初始化镜像文件 /var/lib/tftpboot/ 站点
ls
cp vmlinuz /var/lib/tftpboot/
cp initrd.img /var/lib/tftpboot/
4.1.7准备PXE引导程序
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.1.8安装FTP服务,准备CentOS 7 安装源
4.1.9配置启动菜单文件(默认文件名为default,位于TFTP根目录的pxelinux.cfg子目录下)
mkdir /var/lib/tftpboot/pxelinux.cfg //默认pxelinux.cfg是没有的需要手动创建,注意它是一个目录而非文件虽然是以.cfg结尾
以下为纯手工配置default菜单文件
vim /var/lib/tftpboot/pxelinux.cfg/default
default auto //指定默认入口名称 ,对应下面的label auto
prompt 1 //设置是否等待用户选择,1 表示等待用户控制,0表示不等待用户控制,安装时会出现boot:如果按回车表示选择auto模式
label auto //默认的图形安装
kernel 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
4.1.10关闭防火墙,验证PXE网络安装
做完以上步骤,打开虚拟机安装一台虚拟机。安装成功之后,开启一下,看是否能成功,如果能成功,说明之前的步骤是没有问题,如果有问题则需要去检查之前的内容是不是哪里出错了
。
使用 VMware创建的虚拟机进行测试,虚拟机内存至少需要 2GB,否则在启动安装时可能会报错。
开启虚拟机,在提示字符串“boot:”后直接按Enter键(或执行“auto”命令),将会自动通过网络下载安装文件,并进入默认的图形安装入口
若执行“linux text”命令,则进入文本安装入口;若执行 “linux rescue”命令,则进入救援模式。
五. 实现Kickstart无人值守安装
5.1 准备安装应答文件
1.准备安装应答文件
(1)安装system-config-kickstart工具yum install -y system-config-kickstart
(2)打开"Kickstart配置程序”窗口
通过桌面菜单"应用程序"-->"系统工具"-->"Kickstart”打开或执行"system-config-kickstart”命令打开
(3)配置kickstart选项
基本配置:
默认语言设为"中文(简体)”时区设为"Asia/ shanghai"
设置root密码
高级配置中勾选"安装后重启"。
安装方法:
选FTP
FTP服务器:ftp://192.168.100.100
FTP目录: centos7
准备安装应答文件 yum install -y system-config-kickstart
#在 CentOS 7 系统中安装 system-config-kickstart,工具之后,即可通过图形化向导工具来配置安装应答文件。如果用户对自动应答文件的配置比较熟悉,也可以直接编辑 CentOS 7
安装后自动创建的应答文件(/root/anaconda-ks.cfg),根据需要适当修订后使用。
①、安装system-config-Kickstart工具
②、打开“Kickstart 配置程序”窗口
准备安装应答文件
yum install -y system-config-kickstart #在 CentOS 7 系统中安装 system-config-kickstart 工具之后,即可通过图形化向导工具来配置安装应答文件。如果用户对自动应答文件的配置比较熟悉,也可以直接编辑 CentOS 7 安装后自动创建的应答文件(/root/anaconda-ks.cfg),根据需要适当修订后使用。
配置Kickstart(图形化)
默认语言设为 中文(简体)
时区设为 Asia/Shanghai
设置root密码
高级配置中勾选 安装后重启
安装方法选择 FTP
FTP服务器 ftp://TFTPIP
FTP目录 centos7
引导装载程序选项:安装新引导装载程序
主引导记录:清除主引导记录
分区:删除所有现存分区
磁盘标签:初始化磁盘标签
添加分区:正常分区(需求)
添加网络设备 ens33
网络类型设为 DHCP
验证:无需操作
防火墙:禁用
或者:
③、配置Kickstart选项
安装后脚本的运行
mkdir /etc/yum.repos.d/bak
mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/bak
echo "[local]
name=local
baseurl=ftp://192.168.100.100/centos7
enabled=1
gpgcheck=0" > /etc/yum.repos.d/local.repo
④、保存自动应答文件
⑤、配置需要安装的软件包
如要求最小化安装,可复制下面内容:
vim ks.cfg
%packages
@^minimal
%end
⑥、编辑引导菜单文件 default,添加 ks 引导参数
5.2、验证无人值守安装
当客户机每次以PXE方式引导时,将自动下载 ks.cfg 应答文件,然后根据其中的设置安装CentOS 7 系统,而无需手工干预。
安装成功,dhcp分配ip
六、总结
1、部署PXE远程安装服务
2、实现PXE+kickstart无人值守安装操作系统