统信服务器操作系统行业版V20-1000c【Cobbler 搭建】手册

全文导读:介绍统信服务器操作系统行业版 V20版本上Cobbler 搭建方法。

功能概述

部分用户进行网络安装,不使用PXE,而使用cobbler,该工具来自开源,需要和系统适配。编写cobbler安装配置文档,方便用户在统信服务器操作系统行业版V20 版本上的使用。

使用范围

统信服务器操作系统行业版 V20 -1000c

cobbler工作流程

Server 端

  • 启动 cobbler 服务
  • 进行 cobbler 错误检查,执行 cobbler check 命令
  • 进行配置同步,执行 cobbler sync 命令
  • 复制相关启动文件到 TFTP 目录中
  • 启动 DHCP 服务,提供地址分配
  • DHCP 服务分配 IP 地址
  • TFTP 传输启动文件
  • Server 端接收安装信息
  • Server 端发送 ISO 镜像与 Kickstart 文件

Client 端

  • 客户端以 PXE 模式启动
  • 客户端获取 IP 地址
  • 通过 TFTP 服务器获取启动文件
  • 进入 cobbler 安装选择界面
  • 根据配置信息准备安装系统
  • 加载 Kickstart 文件
  • 传输系统安装的其它文件
  • 进行安装系统

环境准备

  • 测试环境告知,以提供配置时参考:
root 用户登陆状态
网络可以联通
路由器 DHCP 状态:关闭
手动配置 cobbler 配置的服务器端 IP 地址
本机 IP:10.100.20.20
本机设置 DNS:114.114.114.114
本机分配网段及掩码:10.100.20.0 255.255.255.0
网域网关:10.100.20.1
本机 DHCP 设置分配 IP 范围:10.100.20.100 10.100.20.200
  • 关闭防火墙、selinux:
[root@test ~]# systemctl stop firewalld
[root@test ~]# systemctl disable firewalld
[root@test ~]# setenforce 0
[root@test ~]# sed -i 's/^SELINUX=.*/SELINUX=disabled/' /etc/sysconfig/selinux
  • 注意事项:
1、cobbler 服务、DHCP 服务、TFTP 服务均在服务端上统信服务器操作系统V20 版本上来搭建。
2、在部署前需关闭交换机 DHCP 功能,否则会发生 DHCP 分配 IP 冲突无法连接问题导致部署失败。
3、在部署前需要配置好 yum 源。
4、安装 cobbler 及 dhcp httpd xinetd cobbler-web。
[root@test ~]# yum -y install cobbler cobbler-web dhcp-server dhcp  tftp-server xinetd
注意:arm 架构需要再安装:yum install -y python3-distro
5、启动 cobbler 及 httpd 并加入开机启动。
[root@test ~]# systemctl start httpd cobblerd
[root@test ~]# systemctl enable httpd cobblerd

安装步骤

cobbler 配置

第一次配置 cobbler 时,用命令 cobbler check 检查 cobbler 的配置,如果看不到需要配置的选项,再次重启 cobbler。
[root@test ~]# cobbler check
若看到需要配置的若干选项,即开始进行配置。首先使用以下三条命令,设置可动态修改的配置文件:
sed -ri '/allow_dynamic_settings:/c\allow_dynamic_settings: 1' /etc/cobbler/settings
grep allow_dynamic_settings /etc/cobbler/settings
systemctl restart cobbler
设置好可动态修改的配置文件后,参考以下对应的配置命令进行配置:
The following are potential configuration items that you may want to fix:
1 : The 'server' field in /etc/cobbler/settings must be set to something other than localhost, or kickstarting features will not work. This should be a resolvable hostname or IP for the boot server as reachable by all machines that will use it. 1. cobbler setting edit --name=server --value=10.100.20.20 2 : For PXE to be functional, the 'next_server' field in /etc/cobbler/settings must be set to something other than 127.0.0.1, and should match the IP of the boot server on the PXE network. 2. cobbler setting edit --name=next_server --value=10.100.20.20 3 : Please create directory: /tftpboot 3. mkdir /tftpboot 4 : change 'disable' to 'no' in /etc/xinetd.d/tftp 4. sed -ri '/disable/c\disable = no' /etc/xinetd.d/tftp systemctl enable xinetd systemctl restart xinetd 5 : Some network boot-loaders are missing from /var/lib/cobbler/loaders, you may run 'cobbler get-loaders' to download them, or, if you only want to handle x86/x86_64 netbooting, you may ensure that you have installed a *recent* version of the syslinux package installed and can ignore this message entirely. Files in this directory, should you want to support all architectures, should include pxelinux.0, menu.c32, elilo.efi, and yaboot. The 'cobbler get-loaders' command is the easiest way to resolve these requirements. 5. cobbler get-loaders 6 : enable and start rsyncd.service with systemctl 6. systemctl enable rsyncd.service systemctl start rsyncd.service 7 : debmirror package is not installed, it will be required to manage debian deployments and repositories 7. yum -y install debmirror 8 : ksvalidator was not found, install pykickstart 8. yum -y install pykickstart 9 : The default password used by the sample templates for newly installed machines (default_password_crypted in /etc/cobbler/settings) is still set to 'cobbler' and should be changed, try: "openssl passwd -1 -salt 'random-phrase-here' 'your-password-here'" to generate new one 9. 设置 iso 开机 root 密码为 1(根据你的需求自行修改) openssl passwd -1 -salt `openssl rand -hex 4` '1' 得到字符串,复制整个字符串。 cobbler setting edit --name=default_password_crypted --value='字符串' 10 : fencing tools were not found, and are required to use the (optional) power management features. install cman or fence-agents to use them 10. yum -y install fence-agents
[root@test ~]# cobbler check
再次检查后出现
comment out 'dists' on /etc/debmirror.conf for proper debian support comment out 'arches' on /etc/debmirror.conf for proper debian support
意思是需要注释掉:
@dists="sid";
@arches="i386";
使用以下两条命令进行注释:
sed -i 's/@dists="sid";/#@dists="sid";/' /etc/debmirror.conf
sed -i 's/@arches="i386";/#@arches="i386";/' /etc/debmirror.conf
再次检查
[root@localhost ~]# cobbler check
若出现:
No configuration problems found. All systems go.
即 cobbler 配置成功

DHCP 配置

修改 cobbler 的 dhcp 模块,不要直接修改 dhcp 本身的配置文件,因为 cobbler会覆盖。使用以下两条命令开始配置 DHCP:
[root@test ~]# cobbler setting edit --name=manage_dhcp --value=1
[root@test ~]# vim /etc/cobbler/dhcp.template
... subnet 10.100.20.0 netmask 255.255.255.0 { #这里改为分配的网段和掩码 #option routers 10.100.20.1; #如果有网关,这里改为网关地 址 #option domain-name-servers 114.114.114.114; #如果有 DNS,这里改为 DNS 地址 option subnet-mask 255.255.255.0; #改为分配的 IP 的掩码 range dynamic-bootp 10.100.20.100 10.100.20.200; #改为分配的 IP 的范围,注意分配 IP 的范围与实际范围 ...
同步 cobbler 配置:
[root@test ~]# cobbler sync

ISO 配置

提供两种 ISO 文件存放方案:
第一种:
说明:对已有的.iso 文件,通过拷贝方式存放 iso
创建存放.iso 镜像文件的文件夹
mkdir /iso
将你的.iso 镜像文件,拷贝到/iso 文件内
cp *.iso /iso
第二种:
说明:通过挂载.iso 镜像的方式,存放 iso
创建挂载 iso 镜像的文件夹
mkdir /iso
将你的光盘介质或 iso 挂载到/iso
mount -t iso9660 /dev/sr0 /iso/
存放 iso 文件完成后,对 cobbler 导入 iso 镜像:
cobbler import --path=/iso --name=UOS_Server 填写你安装的系统名称 --arch=填写你的系统架构(aarch64、x86_64)
测试环境说明:本机安装系统名称:UOS_Server、架构选择 x86_64
查看导入后镜像:
cobbler distro report --name=UOS_Server-x86_64
进入 cobbler 的 kickstart 配置文件夹:
cd /var/lib/cobbler/kickstarts/
编辑 kickstart 文件:
vim UOS_Server.ks
说明:可随系统名称命名
以下为.ks 文件参考,ks 文件具体化配置根据使用时需求进行修改:
#version=UniontechOS20 # System authorization information auth --enableshadow --passalgo=sha512 # System bootloader configuration bootloader --location=mbr --boot-drive=sda # Partition clearing information clearpart --all --initlabel # Use text mode install #text graphical # Firewall configuration firewall --disabled # Run the Setup Agent on first boot firstboot --disable ignoredisk --only-use=sda # System keyboard keyboard --vckeymap=us --xlayouts='us' # System language lang zh_CN.UTF-8 # Use network installation url --url=$tree # If any cobbler repo definitions were referenced in the kickstart profile, include them here. $yum_repo_stanza # Network information $SNIPPET('network_config') # Reboot after installation reboot #Root password rootpw --iscrypted $default_password_crypted # SELinux configuration selinux --disabled # Do not configure the X Window System skipx # System timezone timezone --utc Asia/Shanghai # Install OS instead of upgrade install # Clear the Master Boot Record zerombr # Allow anaconda to partition the system as needed #autopart part /boot --fstype="xfs" --ondisk=sda --size=500 part swap --fstype="swap" --ondisk=sda --size=2048 part / --fstype="xfs" --ondisk=sda --size=1 --grow part biosboot --fstype="BIOS Boot" --ondisk=sda --size=2 %pre $SNIPPET('log_ks_pre') $SNIPPET('kickstart_start') $SNIPPET('pre_install_network_config') # Enable installation monitoring $SNIPPET('pre_anamon') %end %packages @^minimal-environment @standard %end
指定使用新的 kickstart 文件:
cobbler profile edit --name=UOS_Server-x86_64  --kickstart=/var/lib/cobbler/kickstarts/UOS_Server.ks
验证本次配置的镜像与 ks 文件配置路径:
cobbler profile report --name=UOS_Server-x86_64 |grep Kickstart

开始安装

上述配置好之后,再次同步 cobbler 配置:
cobbler sync
显示同步成功,cobbler 服务器端配置完成。
开启同一网段的其他机器:
开机选择网卡启动,跳转到 PXE 界面,选择安装好的镜像即可。
注意:若虚拟机 PXE 安装启动应该选择网卡启动,安装好后选择本地磁盘启动。配置应该提前设置好内存空间,不能低于 2048Mb。若没有跳转到启动界面,日志消息(/var/log/message)显示 DHCPACK 阶段后,则请检查 xinetd 服务是否开启。

 ©统信软件技术有限公司。访问者可将本网站提供的内容或服务用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。除此以外,将本网站任何内容或服务进行转载,须备注:该文档出自【faq.uniontech.com】统信软件知识分享平台。否则统信软件将追究相关版权责任。

2023-11-09
9 7