基于网启PXE服务器的批量定制系统平台

1.项目说明

  • 该项目共分为2个子项目,由iventoy和定制安装两部分组成

  • 该项目旨在复习巩固系统服务部署使用、shell编程等知识,旨在让学生增加知识面,提高项目实习经历,充实简历

2.项目背景

  • 公司新购了一批服务器和台式机,需要为台式机和服务器安装系统,一部分需要安装国产OpenEuler,一部分要求安装CentOS 7.9,同时也要满足定制化需求,即按要求分区安装相应软件。

3.常见系统批量安装方式

使用商业化软件
  • 使用商业化软件要额外成本开支

使用开源软件
  • Linux 操作系统基于pxe技术结合kickstart实现定制化需求。

  • Linux 操作系统基于cobbler结合自定义ks文件实现定制化需求。

  • windows 系统安装 iventoy 结合自定义配置文件实现定制化需求。

  • U盘装系统,制作u盘启动盘引导安装。

  • 服务器通过ipmi远程ISO安装。

  • 刻录光盘,外接光驱安装系统。

4.项目环境

  • 安装win10/11 笔记本一台、服务器若干、交换机一台

5.任务清单

系统平台部署

  • 安装VmWare17

  • 虚拟出2台计算机

Windows下安装iventoy

  • 前置处理

  • 解压缩部署

配置iventoy

  • 配置网卡信息

  • 配置vmware

测试安装

  • 安装centos7.9

  • 安装openeuler

自动化脚本安装

6.实施步骤

安装下载

  • 注意:下载解压缩iventoy-1.0.20-win64-free.zip,==解压位置的全路径中不能有中文或空格==, 软件解压后的目录结构如下:

  • 各个目录作用如下:

目录说明
data存放 License、配置文件等
doc存放软件相关说明文档
iso放ISO文件的地方,可以在里面创建子目录
lib存放 iVentoy 运行所需的 LIB 文件,==用户不要动这个目录==
log存放 iVentoy 运行日志
user存放用户文件、第三方软件包、自动安装脚本等文件

配置iventoy

拷贝ISO文件
  • 将需要安装的系统ISO文件都拷贝到D:\iventoy-1.0.20-win64-free\iventoy-1.0.20\iso目录下

  • 可以在此目录下任意创建子目录来归类存放各种不同类型系统的ISO文件。

  • 注意:

    • ==目录名和ISO文件名中不能有中文或空格==

    • 也可以管理员身份打开cmd,使用命令创建iso快捷方式(软连接),即不需要将ISO文件从别的位置拷贝到这个 iso 目录下 ( Linux 系统中你可以使用 ln -s 命令)

# 在 Windows 系统中你可以使用 mklink 目标  源 命令创建
​
C:\Users\Administrator>mklink  D:\iventoy-1.0.20-win64-free\iventoy-1.0.20\iso\CentOS-7-x86_64-DVD-2207-02.iso  D:\Linux\Linux_app\ISO\CentOS-7-x86_64-DVD-2207-02.iso
为 D:\iventoy-1.0.20-win64-free\iventoy-1.0.20\iso\CentOS-7-x86_64-DVD-2207-02.iso <<===>> D:\Linux\Linux_app\ISO\CentOS-7-x86_64-DVD-2207-02.iso 创建的符号链接

运行软件
  • Windows 系统中直接双击运行 exe 文件即可

  • Linux 系统下在终端中执行 sudo bash iventoy.sh start 命令。

  • 注意:windows 注意需要关闭防火墙或放行相关端口。==本文采用关闭所有防火墙==,如图:

  • 管理员身份启动iventoy,如图:

image-20250218093701186

  • iVentoy 界面是基于 WEB 的,因此软件运行起来以后,需要打开浏览器访问 http://127.0.0.1:26000 来打开 iVentoy 的软件界面。

  • Windows 系统中打开软件之后,会自动打开浏览器,如果没有自动打开,则需要手动点击 打开链接 按钮,如图:

image-20250218093852420

  • 注意:请使用新版本的 Google Chrome 或 FireFox 浏览器访问 iVentoy 界面,其他浏览器未做测试,不保证没有问题。

  • 分析客户端IP地址设置:打开vmware17->编辑菜单->虚拟网络编辑器->VMnet8 NAT 网卡查看网段,点击NAT设置查看网关地址,注意:需要关闭VMware nat模式的dhcp服务,如图:

启动 PXE 服务
  • 在 iVentoy 主界面上选择本机 IP 地址,根据之前的分析设置好 IP 地址池,然后点击绿色的开始按钮即可,如图:

  • 启动 iventoy 后如图示:

自动启动 PXE 服务
  • Windows 版本可以执行 iVentoy_64.exe -R

  • Linux 版本中可以执行 sudo bash iventoy.sh -R start

  • 其中 -R 选项的意思是按照上一次运行时的参数自动启动 PXE 服务。 这样就不需要再手动点击绿色的开始按钮了,当然前提是之前必须手动设置完参数,启动过一次。在此之后运行时设置的参数会被保存下来,才可以使用 -R 选项。

系统安装

  • 本文使用VMware workstation 新建虚拟机测试,新建虚拟机时==不要加载iso镜像==。

  • 新建Centos7.9虚拟机

image-20250218095142244

image-20250218095224716

注意:新CD/DVD处不能设置ISO镜像文件

  • PEX自动识别:

image-20250218095623130

  • 由于网络安装加载较慢,需要等待一段时间,后续就和正常装机一样,过程略。

image-20240529175435179

iVentoy 定制安装

作用
  • 通过 iVentoy 你无需重新制作ISO文件,只需要简单地为一个ISO文件指定一个或者多个自动安装脚本来实现无人值守、自动安装部署系统的方案。

  • 可以使用 Windows 中的 unattend XML、Redhat/CentOS系列中的 Kickstart 脚本、SUSE系列中的 autoYast XML、Debian系列中的preseed脚本等等。

  • 下面的示例模版脚本位于安装包内的 user/scripts/example 目录下,如图:

发行版脚本格式示例脚本说明
WindowsUnattend XMLunattended.xmlWindows系列
Deepin/UOSINIdeepin.iniDeepin/UOS 系统
RHEL8/CentOS8Kickstart scriptkickstart8.cfg同时也支持基于这几个派生出来的发行版。比如 OpenAnolis, RockyLinux 等。
RHEL7/CentOS7/FedoraKickstart scriptkickstart7.cfg同时也支持基于这几个派生出来的发行版。比如 Oracle Linux, EuroLinux 等。
RHEL6/CentOS6Kickstart scriptkickstart6.cfg同时也支持基于这几个派生出来的发行版。
openEulerKickstart scriptopeneuler.cfgopenEuler 版本。
DebianPreseed scriptpreseed.cfgDebian 系列的发行版。
Ubuntu Server (< 20.x)Preseed scriptpreseed.cfg早期 Ubuntu Server 版本
Ubuntu Server (20.x+)cloud-initcloud-init-user-dataUbuntu Server 20.x 以后的版本
SUSEautoYast XMLautoYast.xmlSLES 和 openSUSE
  • 注意,这里的示例脚本仅供参考,需要根据实际需要修改,尤其是里面磁盘分区设置的部分。否则会造成磁盘被误格式化、数据丢失等问题。

脚本变量扩展
  • 在进行自动安装时,在安装脚本中有一些配置是无法固定写死的,必须根据实际环境进行调整。

  • 最常见的就是对于安装盘的指定,比如我们在安装脚本中指定系统安装到 DISK0 或者 /dev/sda 但在有些机器上它对应的那个盘并不是我们想要的那个。 这样可能就把系统安装到错误的盘上了。

  • 针对上述需求,iVentoy 在自动安装脚本中支持 变量扩展,变量使用 $$VT_XXX$$ 的形式,其中 VT_XXX 对应变量名。

  • 注意:

    • 包含变量的自动安装脚本文件必须是 UTF-8 编码格式。

    • 只支持下面表格中列出的变量,不支持自定义变量。

    • 变量名两边必须各用2个$$ 符号包起来

    • Ventoy 会自动检测自动安装脚本内是否包含变量,对于不包含变量的脚本不会做扩展处理。

    • 变量扩展是在副本中进行的,不会修改脚本源文件。

image-20250218141323252

image-20250218141345576

定制CentOS7
  • 复制 kickstart7.cfg 为 CentOS7.cfg 并修改

install
​
lang en_US.UTF-8
keyboard us
rootpw  123456
firewall --service=ssh
authconfig --enableshadow --passalgo=sha512
selinux --disable
firewall --disabled
timezone --utc Asia/Shanghai
​
#network --onboot=yes --device=$$VT_MAC_COLON_LOWER$$ --bootproto=static --ip=$$VT_LOCAL_IP$$ --netmask=$$VT_NET_MASK$$ --gateway=$$VT_GATEWAY$$ --noipv6
​
eula --agreed
firstboot --disable
​
%include /tmp/partation.ks
zerombr
clearpart --all --initlabel
part /boot --fstype xfs --size 1024
part swap --size 2048
part / --fstype xfs --size 1 --grow
​
​
#packages configuration
%packages
@core
bash-completion
chrony
dos2unix
net-tools
lrzsz
nmap
sysstat
telnet
tree
vim
wget
%end
​
reboot
​
%pre
​
#Select install disk
disk_short_name=$$VT_LINUX_DISK_MAX_SIZE$$
​
echo bootloader --location=mbr --driveorder=$disk_short_name >> /tmp/partation.ks
echo ignoredisk --only-use=$disk_short_name  >> /tmp/partation.ks
echo clearpart --all --initlabel --drives=$disk_short_name  >> /tmp/partation.ks
​
​
%end
​
#Download third part software
%post
​
# wget $$VT_IMG_ID_HTTP_URL$$/Packages/kernel-tools-3.10.0-957.el7.x86_64.rpm -O /root/kernel-tools.rpm
# wget http://$$VT_SERVER_IP$$:$$VT_HTTP_PORT$$/user/xxx.zip -O /root/xxx.zip
​
%end

  • 关闭PEX服务

  • 将设置好的自动部署脚本和镜像关联

image-20250218142231552

测试效果
  • 启动服务

  • 本文使用VMware workstation 新建虚拟机测试,新建虚拟机时不要加载iso镜像,测试CentOS7,按回车键。

image-20250218142438532

  • 切换到自定义脚本,然后按 回车键

image-20250218142508140

  • 由于网络安装加载较慢,需要等待一段时间,安装按预先设定脚本执行

image-20240530145000491

  • 安装完毕后,登录系统检查

# 分区检查
​
[root@localhost ~]# lsblk
NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sda      8:0    0   20G  0 disk 
├─sda1   8:1    0    1G  0 part /boot
├─sda2   8:2    0    1G  0 part [SWAP]
└─sda3   8:3    0   18G  0 part /
sr0     11:0    1 1024M  0 rom  
# 软件包检查
​
[C:\~]$ ssh root@192.168.88.200
​
​
Connecting to 192.168.88.200:22...
Connection established.
To escape to local shell, press 'Ctrl+Alt+]'.
​
WARNING! The remote SSH server rejected X11 forwarding request.
Last login: Thu May 30 14:56:50 2023
[root@localhost ~]# rpm -aq | egrep "vim|wget|tree|bash-completion|lrzsz"
vim-filesystem-7.4.629-7.el7.x86_64
bash-completion-2.1-8.el7.noarch
wget-1.14-18.el7_6.1.x86_64
vim-enhanced-7.4.629-7.el7.x86_64
vim-minimal-7.4.629-7.el7.x86_64
vim-common-7.4.629-7.el7.x86_64
tree-1.6.0-10.el7.x86_64
lrzsz-0.12.20-36.el7.x86_643
  • 检查防火墙和SELinux。

[root@localhost ~]# firewall-cmd --state
not running
[root@localhost ~]# getenforce 
Disabled

问题总结

  • 需要关闭Windows的所有防火墙及杀毒等安全软件

  • iVentoy_64.exe执行文件需要以管理员身份打开

  • iVentoy exe文件双击运行若无反应,需要下载所有运行库: VS2019,下载链接:最新受支持的 Visual C++ 可再发行程序包下载 | Microsoft Learn

  • 本项目是在虚拟机中模拟的,若安装某些系统时卡死,一般都是虚拟机分配的内存不足造成的,建议分配4096m内存,如图:

image-20250218144809705

  • 本项目实验需要使用vmnet8网卡,若无法使用则无法完成,需要在设备管理器中检查vmnet8网卡驱动是否安装,若有问题则在虚拟网络编辑器中进行还原默认值设置。

  • 若网络引导到系统安装界面花屏(一般为Windows系列),需要更改iventoy的分辨率,由默认的1024*768修改为较高分辨率

image-20250218144721568

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值