PXE高效批量网络装机

目录

1、部署 PXE 远程安装服务

2、搭建PXE远程安装服务器

3、实现 Kickstart 无人值守安装


1、部署 PXE 远程安装服务

    在大规模的 Linux 应用环境中,如 Web 群集、分布式计算等,服务器往往并不配备光驱
设备,在这种情况下,如何为数十乃至上百台服务器裸机快速安装系统呢?传统的 USB 光驱、
移动硬盘等安装方法显然已经难以满足需求。

PXE远程安装服务的优点

●规模化:同时装配多台服务器;
●自动化:安装系统、配置各种服务;
●远程实现:不需要光盘、 U 盘等安装介质。

   PXE 是由 Intel 公司开发的网络引导技术,工作在 Client/Server 模式,允许客户机通
过网络从远程服务器下载引导镜像,并加载安装文件或者整个操作系统。若要搭建 PXE 网络
体系,必须满足以下几个前提条件。

●客户机的网卡支持 PXE 协议(集成 BOOTROM 芯片),且主板支持网络引导。
●网络中有一台 DHCP 服务器以便为客户机自动分配地址、指定引导文件位置。
●服务器通过 TFTP(Trivial File Transfer Protocol,简单文件传输协议)提供引导镜像文件的下载。

其中,第一个条件实际上是硬件要求,目前绝大多数服务器和大多数 PC 都能够提供此
支持,只需在 BIOS 设置中允许从 Network 或 LAN 启动即可。下面将介绍 PXE 远程安装服务
的基本部署过程。


2、搭建PXE远程安装服务器

####准备 CentOS 7 安装源##
CentOS 7 的网络安装源一般通过 HTTP、 FTP 协议发布,另外也支持 NFS(Network File
System,网络文件系统)协议,关于 NFS 的配置请参阅其他资料,这里不再赘述。
例如,若采用 FTP 协议发布安装源,可以在服务器上部署一个 YUM 软件仓库。搭建yum仓库的方法这里就不再赘述了,我以后可能会写。不知道的可以去搜一下。

####注意啦#####
架设ftp一定要关闭防火墙和核心防护
#####

yum仓库搭建完毕后,就可以安装ftp服务了,因为是服务端,所以安装的是vsftpd程序

[root@localhost ~]# mkdir -p /var/ftp/centos7
[root@localhost ~]# mount /dev/cdrom /mnt
[root@localhost ~]# cp -rf /mnt/* /var/ftp/centos7
[root@localhost ~]# yum -y install vsftpd
[root@localhost ~]# systemctl start vsftpd
[root@localhost ~]# systemctl enable vsftpd

####安装并启用 TFTP 服务###
TFTP 服务由 tftp-server 软件包提供,配置文件位于/etc/xinetd.d/tftp。配置时只
要将“disable = yes”改为“disable = no”,然后启动 TFTP 服务即可。

[root@localhost ~]# yum -y install tftp-server
[root@localhost ~]# vi /etc/xinetd.d/tftp

service tftp
{
####省略部分信息
protocol = udp                                            ###TFTP 采用 UDP 传输协议
server = /usr/sbin/in.tftpd
server_args = -s /var/lib/tftpboot             ###指定 TFTP 根目录
disable = no
####省略部分信息
}

[root@localhost ~]# systemctl start tftp                            ###启动tftp服务
[root@localhost ~]# systemctl enable tftp                        ###设置成开机自启

####准备 Linux 内核、初始化镜像文件#####
       用于 PXE 网络安装的 Linux 内核、初始化镜像文件可以从 CentOS 7 系统光盘获得,分
别为 vmlinuz 和 initrd.img,位于文件夹 images/pxeboot 下。找到这两个文件并将其复制
到 tftp 服务的根目录下。

[root@localhost ~]#   cd /mnt/images/pxeboot/          ####切换到挂载目录/mnt/images/pxeboot/   

[root@localhost pxeboot]# cp vmlinuz initrd.img /var/lib/tftpboot/  ###两个文件并将其复制到 tftp 服务的根目录下

####准备 PXE 引导程序####
用于 PXE 网络安装的引导程序为 pxelinux.0,由软件包 syslinux 提供。安装好软件包
syslinux,然后将文件 pxelinux.0 也复制到 tftp 服务的根目录下。

[root@localhost ~]# yum -y install syslinux
[root@localhost pxeboot]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/

####安装并启用 DHCP 服务####
       由于 PXE 客户机通常是尚未装系统的裸机,因此为了与服务器取得联系并正确下载相关
引导文件,需要预先配置好 DHCP 服务来自动分配地址并告知引导文件位置。如 PXE 服务器
的 IP 地址为 20.0.0.254, DHCP 地址池为 20.0.0.100~20.0.0.200,则可以参考
以下操作来搭建 DHCP 服务器。

[root@localhost ~]# yum -y install dhcp
[root@localhost ~]# vi /etc/dhcp/dhcpd.conf
####省略部分信息#####
subnet 20.0.0.0 netmask 255.255.255.0 {
option routers 20.0.0.2;                          ###这是网关
option subnet-mask 255.255.255.0;
option domain-name "bdqn.com";
option domain-name-servers 114.114.114.114,8.8.8.8;
default-lease-time 21600;
max-lease-time 43200;
range 20.0.0.100 20.0.0.200;
next-server 20.0.0.55;                         #####指定 TFTP 服务器的地址
filename "pxelinux.0";                        ####指定 PXE 引导程序的文件名
}

[root@localhost ~]# systemctl start dhcpd
[root@localhost ~]# systemctl enable dhcpd


      从上述过程可以看到,与一般 DHCP 服务不同的是,配置文件中增加了 netx-server 和
filename 这两行记录,分别用来指定 TFTP 服务器的地址和 PXE 引导程序的文件名。

####配置启动菜单文件#####
       启动菜单用来指导客户机的引导过程,包括如何调用内核,如何加载初始化镜像。默认
的启动菜单文件为 default,应放置在 tftp 根目录的 pxelinux.cfg 子目录下,典型的启动
菜单配置可参考以下操作手动建立。

[root@localhost ~]# mkdir /var/lib/tftpboot/pxelinux.cfg
[root@localhost ~]# vi /var/lib/tftpboot/pxelinux.cfg/default
default auto                                                ###指定默认入口名称
prompt 1                                                        ###1 表示等待用户控制
label auto
    kernel vmlinuz
    append initrd=initrd.img method=ftp://20.0.0.55/centos7
label linux text
    kernel vmlinuz
    append text initrd=initrd.img method=ftp://20.0.0.55/centos7
label linux rescue
    kernel vmlinuz
    append rescue initrd=initrd.img method=ftp://20.0.0.55/centos7

上述配置记录中定义了三个引导入口,分别为图形安装(默认)、文本安装、救援模式。
其中, prompt 用来设置是否等待用户选择; label 用来定义并分隔启动项; kernel 和 append
用来定义引导参数。引导入口的个数及内容根据需要自行定义。例如,实现无人值守安装时
只需要一个入口就够了。

####验证 PXE 网络安装####

搭建好 PXE 远程安装服务器以后,就可以使用客户机进行安装测试了。对于新购买的服
务器或 PC 裸机,一般不需要额外设置;若要为已有系统的主机重装系统,则可能需要修改
BIOS 设置,将“Boot First”设为“NETWORK”或“LAN”,然后重启主机;

若使用 VMware创建的虚拟机进行测试,要去掉编辑——>虚拟网络编辑器——>Vmnet8下的启用本地DHCP服务;虚拟机内存至少需要 2GB,否则在启动安装时会报错。
如果服务器配置正确,网络连接、 PXE 支持等都没有问题,则客户机重启后将自动配
置 IP 地址,然后从 TFTP 服务器中获取引导程序 pxelinux.0,并根据引导菜单配置提示用
户指定启动入口,


在提示字串“boot:”后直接按 Enter 键(或执行“auto”命令),将会进入默认的图形
安装入口;若执行“linux text”命令,则进入文本安装入口;若执行“linux rescue”命
令,则进入救援模式。
直接按 Enter 键确认后将自动通过网络下载安装文件,并进入图形安装程序界面,如图
6.2 所示。若能够成功到达这一步,说明 PXE 网络安装基本成功。后续安装步骤与使用光盘
的正常安装类似,这里不再叙述。

3、实现 Kickstart 无人值守安装

  通过 PXE 技术远程安装 CentOS 7 系统的方法,安装介质不再受限于光盘、
移动硬盘等设备,大大提高了系统安装的灵活性。然而,安装期间仍需要手动选择语言、键
盘类型、指定安装源等一系列交互操作,当需要批量安装时非常不方便。
      本节将进一步学习如何实现无人值守自动安装,通过使用 Kickstart 工具配置安装应答
文件,自动完成安装过程中的各种设置,从而无须手动干预,提高网络装机效率。
#####注意啦!安装图形界面###
[root@localhost ~]#  yum -y groupinstall 'GNOME Desktop'        ###安装图形界面工具
[root@localhost ~]# systemctl set-default graphical.target        ###图形界面启动

#####准备安装应答文件####
      在 CentOS 7 系统中安装 system-config-kickstart 工具之后,即可通过图形化向导工
具来配置安装应答文件。如果用户对自动应答文件的配置比较熟悉,也可以直接编辑 CentOS
7 安装后自动创建的应答文件(/root/anaconda-ks.cfg),根据需要适当修订后使用。

[root@localhost ~]# yum -y install  system-config-kickstart        ###安装kickstart

####配置安装应答参数####
通过桌面菜单“应用程序”→“系统工具”→“Kickstart”即可打开“Kickstart 配
置程序”窗口。在“Kickstart 配置程序”窗口中,可以针对基本配置、安装方法、引导装
载程序选项、分区信息、网络配置等各种安装设置进行指定
########基本配置##########

基本配置:
    默认语言:Chinese (P.R. of China)---中文(简体)
    键盘:U.S English
    时区:Asia/Shanghai
    Root密码:Abc123
    默认密码:Abc123
    勾选√:给root密码加密
高级配置:
    目标架构:X86、AMD64、活IntelEm64T
    勾选√:安装后重启
    不勾选:在文本模式中执行安装(默认为图形化模式)

########安装方法##########
安装方法:
    勾选√:执行全新安装

安装方法:
    勾选√:FTP  
    FTP服务器:ftp://20.0.0.21
    FTP目录:centos7


########引导装载程序选项######
安装类型:
    勾选√:安装新引导装载程序

########分区信息##########
在“分区信息”界面中,需正确规划硬盘分区方案。例如,可划分一个 500MB 的/boot
分区、 4GB 的/home 分区、 2GB 的 swap 分区,将剩余空间划分给根分区

/boot       xfs     是       1024
/home      xfs     是     4096
swap        swap     是     2048
/    xfs    是    1
########################

#####网络配置及防火墙配置####
在“网络配置”界面中,添加一个网络设备“ens33”,将网络类型设为“DHCP”。
在“防火墙配置”界面中,可以选择禁用 SELinux、禁用防火墙。

#####软件包选择#####
CentOS 7 系统开始不再提供软件包的选择,如图 6.6 所示。如果需要安装软件包,可
以根据需要将/root/anaconda-ks.cfg 的软件包安装脚本复制到 ks.cfg 文件中,只需要复
制%packages 到%end 部分即可,在%packages 到%end 之间,包含以@开头的软件包列表,将
不需要的软件名删除,剩下的就是系统会自动安装的软件包。例如,仅保留以下内容即为采
用最小化安装

####
%packages
@^minimal
%end
####

 

###安装脚本###
在“预安装脚本”界面、“安装后脚本”界面中,可以分别添加在安装前、安装后自动
运行的可执行语句。此项设置使服务器的自动化配置变得更加容易。例如,可以使客户机在
完成安装后自动设置 YUM 软件仓库。需要注意的是,应确保所编写的代码能
够正确执行,以免安装失败。

###其他信息###
若没有特殊需求,在“验证”界面、“显示配置”界面中,保持默认设置就可以了

####安装脚本后####
勾选√:使用解释程序:/bin/bash
在下面键入您的%post脚本:

rm -rf /etc/yum.repos.d/*
echo -e '[base]\nname=CentOS7.9\nbaseurl=ftp://20.0.0.55/centos7\nenabled=1\ngpgcheck=1\ngpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7'>/etc/yum.repos.d/centos7.repo

####保存自动应答文件####
选择“Kickstart 配置程序”窗口的“文件”→“保存”命令,指定目标文件夹、文件
名,将配置好的应答参数保存为文本文件,如/root/ks.cfg。以后若要修改此应答配置,可
以在“Kickstart 配置程序”窗口中打开进行调整,或者直接用 VI 等文本编辑工具进行修改

#############采用手动编辑  #################

[root@localhost ftp]# cat ks.cfg
#version=DEVEL
# Use network installation
url --url="ftp://20.0.0.21/centos7"
# Use text mode install 
text
reboot
# System authorization information
auth --enableshadow --passalgo=sha512
# Run the Setup Agent on first boot
firstboot --enable
ignoredisk --only-use=sda
# Keyboard layouts
keyboard --vckeymap=us --xlayouts='us'
# System language
lang en_US.UTF-8
 
# Network information
network  --bootproto=dhcp --device=ens33 --ipv6=auto --activate
network  --hostname=localhost.localdomain
 
# Root password
rootpw --iscrypted $1$M14l7E9w$Hvn1NTMW0uSUpkh99rJUJ1
# System services
services --disabled="chronyd"
# System timezone
timezone Asia/Shanghai --isUtc --nontp
user --name=ningmeng --password=$6$HKbLyKFeh5SNc5GQ$1Pu.e/zWxzqcvinnzRw4MylFgX5pkzStRLQp7U5aMgevpXOfWyOOijTDPtju.cY7b/nvtKLnGF0qlV.I4r1vB. --iscrypted --gecos="ningmeng"
# System bootloader configuration
bootloader --append=" crashkernel=auto" --location=mbr --boot-drive=sda
# Partition clearing information
clearpart --none --initlabel
# Disk partitioning information
part swap --fstype="swap" --ondisk=sda --size=2048
part /boot --fstype="xfs" --ondisk=sda --size=1024
part /data --fstype="xfs" --ondisk=sda --size=10240
part / --fstype="xfs" --ondisk=sda --size=5000
 
%packages
@^minimal
@core
kexec-tools
 
%end
 
%addon com_redhat_kdump --enable --reserve-mb='auto'
 
%end
 
%anaconda
pwpolicy root --minlen=6 --minquality=1 --notstrict --nochanges --notempty
pwpolicy user --minlen=6 --minquality=1 --notstrict --nochanges --emptyok
pwpolicy luks --minlen=6 --minquality=1 --notstrict --nochanges --notempty
%end

####实现批量自动装机####
有了自动安装的应答文件之后,只要将其放置 PXE 安装服务器的 FTP 目录下,并适当修
改引导菜单,就可以实现基于网络的批量自动装机了。

1、启用自动应答文件
在 PXE 远程安装服务器中,将上一节建立的应答文件复制到/var/ftp 目录下,
使客户机能够通过 ftp://20.0.0.55/ks.cfg 访问;然后编辑引导菜单文件
default,添加 ks 引导参数以指定 ks.cfg 应答文件的 URL 路径。

[root@localhost ~]# cp /root/ks.cfg /var/ftp/ks.cfg
[root@localhost ~]# vi /var/lib/tftpboot/pxelinux.cfg/default
default auto
prompt 0                                                         ###0表示不等待
label auto
    kernel vmlinuz
    append initrd=initrd.img method=ftp://20.0.0.55/centos7 ks=ftp://20.0.0.55/ks.cfg

启用自动应答安装之后,当客户机每次以 PXE 方式引导时,将自动下载 ks.cfg 应答配
置文件,然后根据其中的设置安装 CentOS 7 系统,而无须手工干预

客户机安装完成以后,检查其 YUM 软件仓库配置,可以发现已经按照“安装后脚本”的
设置删除了/etc/yum.repos.d目录下的所有文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值