KylinV10SP2实现ARM和x86架构系统PXE部署(S3)
本文介绍在esxi(虚拟化)中Centos7.9操作系统上部署PXE服务端,集成麒麟系统安装源,TFTP服务,DHCP服务,HTTP服务,能够向裸机发送PXE引导程序、Linux内核、启动菜单等数据,以及提供安装文件。
系统引导模式分为uefi引导以及legacy引导,本文主要UEFI,现在新的服务器基本不再使用传统模式引导。
(1)2.6步骤为必填项
(2)ks文件,dhcp配置文件,grub引导文件等配置均作为示例进行参考,请实际情况进行更改。
(3)测试的客户端内存必须≥4GB,否则加载会报错no space left on device
(4)esxi测试过程中虚拟机裸机的网卡与服务端在同一组虚拟交换机
(5)uefi引导,legacy引导设置步骤:右击虚拟机名称–>编辑设置–>虚拟机选项–>引导选项–>固件
如果没有物理机充当服务器也可以用VMware Workstation 创建虚拟机做,系统配置都一样
感谢下面两位大佬文档参考
银河麒麟服务器系统PXE部署_服务器用网络安装装麒麟系统-CSDN博客
麒麟kylinV10实现arm和x86无人值守安装PXE(实施篇)_pxe-system-type-CSDN博客
一 系统环境
1.1 服务端/客户端系统版本
[root@plzj-s3-kylin ~]# cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
1.2 服务端环境信息
IP地址: 172.16.250.251
子网掩码: 255.255.255.0
网关: 172.16.250.1
分配地址段: 172.16.250.{100-130}
uefi引导需要的文件: grubx64.efi
legacy引导需要的文件:pxelinux.0
ISO镜像:Kylin-Server-10-SP2-Release-Build09-20210524-x86_64.iso;Kylin-Server-10-SP2-Release-Build09-20210524-arm64.iso
二 组件安装部署
2.1 安装软件包
2.1.1 uefi配置
[root@plzj-s3-kylin ~]# yum install -y dhcp tftp tftp-server httpd xinetd pykickstart
其中pykickstart包提供的`ksvalidator`命令行工具。以下是一个简单的命令行示例,用于检查ks文件的语法:
ksvalidator /var/www/html/ks/kylin-ks.cfg
2.1.2 legacy配置
yum install -y dhcp tftp tftp-server httpd xinetd syslinux-nonlinux
2.2 dhcp服务配置
2.2.1 uefi配置
[root@plzj-s3-kylin ~]# cp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf
[root@plzj-s3-kylin ~]# vim /etc/dhcp/dhcpd.conf
ddns-update-style interim;
allow booting;
allow bootp;
ignore client-updates;
set vendorclass = option vendor-class-identifier;
# 引用模块判断裸机类型是x86还是arm
option pxe-system-type code 93 = unsigned integer 16;
# 配置要分配的地址段及netmask, 需要修改为自己的网段
subnet 172.16.250.0 netmask 255.255.255.0 {
# 配置网关,如dhcp有问题,注意网关的配置
option routers 172.16.250.1;
# 配置netmask
option subnet-mask 255.255.255.0;
# 分配的ip范围
range dynamic-bootp 172.16.250.100 172.16.250.130;
# 缺省租约时间
default-lease-time 7200;
# 最大租约时间
max-lease-time 14400;
# 指定引导装机的ip
next-server 172.16.250.251;
class "pxeclients" {
match if substring (option vendor-class-identifier, 0, 9) = "PXEClient";
# x86服务器引导
if option pxe-system-type = 00:07 or option pxe-system-type = 00:09 {
filename "x86_uefi/BOOTX64.EFI";
}
# arm服务器引导
else if option pxe-system-type = 00:0b {
filename "arm_uefi/BOOTAA64.EFI";
}
else {
filename "pxelinux.0";
}
}
}
通过pxe-system-type选项可以指定x64、ARM64和LoongArch64使用不同的引导文件,07和09为x64 UEFI;0b为ARM UEFI;27为LoongArch64的UEFI。
在客户端下租约文件在/var/lib/dhclient/dhclient.leases;在服务器端的租约文件在/var/lib/dhcpd/dhcpd.leases,pxe-system-type可以通过查看/var/lib/dhcpd/dhcpd.leases获取
2.3 xinetd服务配置
[root@plzj-s3-kylin ~]# vim /etc/xinetd.d/tftp
文件中:disable yes改成no
2.4 http服务配置
2.4.1 uefi配置
(1)创建ARM和X86安装源文件夹
mkdir /var/www/html/{kylin_x86,kylin_arm}
(2)将系统镜像拷贝至安装源文件夹下
mkdir /mnt/{arm,x86}
mount /dev/sr0 /mnt/x86
rsync -a /mnt/x86/ /var/www/html/kylin_x86
切换虚拟机镜像挂载重复上述操作
umount /dev/sr0
mount /dev/sr0 /mnt/arm
rsync -a /mnt/arm/ /var/www/html/kylin_arm
chmod -R 755 /var/www/html/
(3)将客户端启动引导所需文件拷贝至/var/lib/tftpboot/目录下
mkdir /var/lib/tftpboot/{arm_uefi,x86_uefi}
#ARM配置引导文件
cp -r /var/www/html/kylin_arm/EFI/BOOT/* /var/lib/tftpboot/arm_uefi/
cp /var/www/html/kylin_arm/images/pxeboot/* /var/lib/tftpboot/arm_uefi/
#X86配置引导文件
cp -r /var/www/html/kylin_x86/EFI/BOOT/{grubx64.efi,BOOTX64.EFI} /var/lib/tftpboot/x86_uefi/
cp /var/www/html/kylin_x86/images/pxeboot/* /var/lib/tftpboot/x86_uefi/
2.5 grub配置
2.5.1 uefi配置
#X86 grub.cfg配置
[root@plzj-s3-kylin ~]# vim /var/lib/tftpboot/x86_uefi/grub.cfg
set default="0"
function load_video {
insmod efi_gop
insmod efi_uga
insmod video_bochs
insmod video_cirrus
insmod all_video
}
load_video
set gfxpayload=keep
insmod gzio
insmod part_gpt
insmod ext2
set timeout=5
### END /etc/grub.d/00_header ###
search --no-floppy --set=root -l 'kylin-Server V10 SP2 x86_64'
### BEGIN /etc/grub.d/10_linux ###
menuentry 'Install Kylin Linux Advanced Server V10 SP2 x86_64' --class fedora --class gnu-linux --class gnu --class os {
linuxefi x86_uefi/vmlinuz ro inst.ks=http://172.16.250.251/kylin-ks_x86.cfg
initrdefi x86_uefi/initrd.img
}
#ARM grub.cfg配置
[root@plzj-s3-kylin ~]# vim /var/lib/tftpboot/arm_uefi/grub.cfg
set default="0"
function load_video {
if [ x$feature_all_video_module = xy ]; then
insmod all_video
else
insmod efi_gop
insmod efi_uga
insmod ieee1275_fb
insmod vbe
insmod vga
insmod video_bochs
insmod video_cirrus
fi
}
load_video
set gfxpayload=keep
insmod gzio
insmod part_gpt
insmod ext2
set timeout=3
### END /etc/grub.d/00_header ###
search --no-floppy --set=root -l 'kylin-Server V10 SP2 arm_64'
### BEGIN /etc/grub.d/10_linux ###
menuentry 'Install Kylin Linux Advanced Server V10 SP2 arm_64' --class red --class gnu-linux --class gnu --class os {
linux arm_uefi/vmlinuz ro inst.ks=http:172.16.250.251/kylin-ks_arm.cfg
initrd arm_uefi/initrd.img
}
2.6 ks文件配置
pykickstart包提供的
ksvalidator
命令行工具。以下是一个简单的命令行示例,用于检查ks文件的语法:
ksvalidator /var/www/html/kylin-ks_arm.cfg
#x86和arm相同自行配置
[root@plzj-s3-kylin ~]# vim /var/www/html/kylin-ks_x86.cfg
#vsrsion=DEVEL
# 此处为安装镜像源地址
install
url --url=http://172.16.250.251/kylin_x86/
# Use graphical install
graphical
# 安装系统完成后自动重启
reboot
# 键盘布局Keyboard layouts
keyboard --xlayouts='cn'
# 语言支持System language
lang zh_CN.UTF-8 --addsupport=en_US.UTF-8
#关闭防火墙,禁用selinux
firewall --disabled
selinux --disabled
services --disabled="kdump"
services --disabled="chronyd"
# Run the Setup Agent on first boot
firstboot --enable
# 安装位置磁盘分区
ignoredisk --only-use=sda
# Partition clearing information
clearpart --all --initlabel
# Disk partitioning information
part /boot --fstype="xfs" --size=1024
part /boot/efi --fstype="efi" --size=600 --fsoptions="umask=0077,shortname=winnt"
part pv.116 --fstype="lvmpv" --grow --size=1
volgroup klas --pesize=4096 pv.116
logvol swap --fstype="swap" --size=32768 --name=swap --vgname=klas
logvol / --fstype="xfs" --size=102400 --name=root --vgname=klas
logvol /home --fstype="xfs" --grow --size=1 --name=home --vgname=klas
# 键盘布局,语言支持
# Keyboard layouts
keyboard --xlayouts='cn'
# System language
lang en_US.UTF-8 --addsupport=en_US.UTF-8
%post --nochroot
#####copy kyinfo and LICENSE
if [ -e /tmp/.kyinfo ];then
echo y | cp -a /tmp/.kyinfo $ANA_INSTALL_PATH/etc/
fi
if [ -e /tmp/LICENSE ];then
echo y | cp -a /tmp/LICENSE $ANA_INSTALL_PATH/etc/
fi
if [ -e /run/install/repo/.kyinfo ];then
echo y | cp -a /run/install/repo/.kyinfo $ANA_INSTALL_PATH/etc/
fi
if [ -e /run/install/repo/LICENSE ];then
echo y | cp -a /run/install/repo/LICENSE $ANA_INSTALL_PATH/etc/
fi
##### kylin postaction
## cdrom install, copy .kylin-post-actions
if [ -e /run/install/repo/.kylin-post-actions ];then
echo y | cp -a /run/install/repo/.kylin-post-actions /tmp/.kylin-post-actions
echo "repo=/run/install/repo" > /tmp/.kylin-repo
fi
## copy kylin post scripts in new os
if [ -e /tmp/.kylin-post-actions ];then
echo y | cp -a /tmp/.kylin-post-actions $ANA_INSTALL_PATH/bin
fi
if [ -e /tmp/.kylin-repo ];then
echo y | cp -a /tmp/.kylin-repo $ANA_INSTALL_PATH/tmp/
fi
## copy and run .kylin-post-actions-nochroot
if [ -e /run/install/repo/.kylin-post-actions-nochroot ];then
echo y | cp -a /run/install/repo/.kylin-post-actions-nochroot /tmp/.kylin-post-actions-nochroot
fi
if [ -e /tmp/.kylin-post-actions-nochroot ];then
/bin/bash -x /tmp/.kylin-post-actions-nochroot &> $ANA_INSTALL_PATH/var/log/.kylin-post-actions-nochroot.log
fi
%end
%post
systemctl disable systemd-networkd-wait-online.service
systemctl disable multipathd.service
systemctl stop kdump
### do kylin post action
if [ -e /bin/.kylin-post-actions ];then
/bin/bash -x /bin/.kylin-post-actions &> /var/log/.kylin-post-actions.log
fi
%end
# 软件包选择
%packages
@^kylin-desktop-environment
@development
@man-help
@system-tools
%end
# 网络和主机名 Network information
network --bootproto=dhcp --device= --ipv6=auto --activate
network --hostname=plzj-kylin-arm
# 时间和日期
timesource --ntp-disable
# System timezone
timezone Asia/Shanghai --utc
#默认勾选许可
eula --agreed
# Root密码
# Root password "Kylin123123"
rootpw --iscrypted $6$2RNyJf8iEMumDVFd$jGlgTmmUkLG2NquH9zUfa/S/UJKsBuF5PXdbKdosRYxQOzh4uWaq9tuxL/EwSCmgsjnRNWXu66ILmtSbIBDn.0
%anaconda
pwpolicy root --minlen=8 --minquality=1 --strict --nochanges --notempty
pwpolicy user --minlen=8 --minquality=1 --strict --nochanges --emptyok
pwpolicy luks --minlen=8 --minquality=1 --strict --nochanges --notempty
%end
2.7 重启服务
systemctl enable httpd && systemctl restart httpd
systemctl enable dhcpd && systemctl restart dhcpd
systemctl enable xinetd && systemctl restart xinetd
systemctl enable tftp && systemctl restart tftp
systemctl disable firewalld && systemctl stop firewalld
2.8 客户端测试
PXE安装操作系统(UEFI+Legacy)
问题描述
Taishan服务器BIOS只支持UEFI模式,客户PXE安装操作系统BIOS均为Legacy模式
解决方案
UEFI和Legacy模式PXE安装操作系统原理一致,不同模式安装仅有启动文件不同,UEFI模式下获取对应的启动文件即可
pxe文件获取(UEFI)模式:
1. 执行mount /dev/cdrom /mnt命令将光盘挂载至/mnt目录下
2. 执行cd /mnt/EFI/BOOT/命令进入光盘启动文件目录下
3. 执行cp BOOTX64.EFI grub.cfg grubx64.efi /var/lib/tftpboot/ cp /mnt/isolinux/{vmlinuz,initrd.img} /var/lib/tftpboot/
命令将相关启动文件复制到tftp服务根目录下
4. 执行vim /var/lib/tftpboot/grub.cfg命令编辑grub.cfg文件
set default="0"
set timeout=3
menuentry 'Install CentOS Linux 8.0.1905' {
linuxefi /vmlinuz ip=dhcp ks=http://PXE源服务器IP地址/ks.cfg
initrdefi /initrd.img
}