阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Kickstart部署之NFS架构

157次阅读
没有评论

共计 4866 个字符,预计需要花费 13 分钟才能阅读完成。

一 准备

1.1 完整架构:Kickstart+DHCP+NFS+TFTP+PXE

1.2 组件应用
Kickstart 服务端 IP:172.24.8.12
DHCP:提供客户端 IP,网关,镜像路径等;
TFTP:共享 pxelinux.0、initrd.img、vmlinux、isolinux.cfg、boot.msg、vesamenu.c32、splash.png 文件
NFS:共享 ks.cfg、及所有光盘文件

注意:此 ks.cfg 文件和所有光盘文件也可通过 HTTP、FTP 等方式共享,参考其他笔记即可。

1.3 TFTP 等组件安装

[root@server ~]# yum -y install dhcp* tftp* rpcbind nfs-utils
[root@server ~]# yum -y install xinetd  #tftp 依赖于 xinetd,因此需要安装 xinetd

1.4 挂载系统光盘

[root@localhost ~]# mount /dev/sr0 /mnt/cdrom/

1.5 关闭防火墙及 SELinux

[root@server ~]# systemctl stop firewalld.service
[root@server ~]# systemctl disable firewalld.service
[root@server ~]# setenforce 0
[root@server ~]# vi /etc/selinux/config    #彻底关闭 SELinux
SELINUX=disabled

二 服务端的配置

2.1 配置 DHCP

[root@server ~]# vi /etc/dhcp/dhcpd.conf
option domain-name-servers 223.5.5.5,223.6.6.6;  #全局 DNS
default-lease-time 600;     #默认的租赁时间
max-lease-time 7200;     #最大可租赁时间
subnet 172.24.8.0 netmask 255.255.255.0 {#设置网段
range 172.24.8.13 172.24.8.50;    #设置可分配地址池
option routers 172.24.8.2;    #默认网关
next-server 172.24.8.12;     #tftp server 的 ip
filename “pxelinux.0”;}     #pxe boot 需要的启动文件名, 相当于 bootloader
[root@server ~]# systemctl start dhcpd.service  #启动 dhcp 服务
[root@server ~]# systemctl enable dhcpd.service  #开机自动启动

2.2 NFS 配置

[root@server ~]# mkdir /CentOSinstall    #创建 nfs 共享目录
[root@server ~]# chown nfsnobody:nfsnobody /centosinstall/ #修改目录所有者
[root@server ~]# vi /etc/exports
 /centosinstall 172.24.8.0/24(rw,sync)
[root@server ~]# cp /mnt/cdrom/* /centosinstall/  #将光盘下所有文件拷贝到 nfs 目录下
[root@server ~]# systemctl start rpcbind.service
[root@server ~]# systemctl enable rpcbind.service
[root@server ~]# systemctl start nfs-server.service
[root@server ~]# systemctl enable nfs-server.service

2.3 配置 TFTP

[root@localhost ~]# vi /etc/xinetd.d/tftp
service tftp
{
  ……
    server  = /usr/sbin/in.tftpd
    server_args = -s /var/lib/tftpboot    #此为 TFTP 服务根目录
    disable  = no                               #打开 TFTP
    ……
}
[root@server ~]# systemctl start xinetd.service   #启动 xinetd,则 xinetd 管理的 tftp 也会启动
[root@server ~]# systemctl enable xinetd.service  #开机启动 xinetd,则 xinetd 管理的 tftp 也会启动

2.4 TFTP 文件配置

# 在 TFTP 目录中指定相关 PXE 内核模块及相关参数
[root@server ~]# yum -y install syslinux   #Linux 引导加载程序
[root@server ~]# find / -name pxelinux.0
/usr/share/syslinux/pxelinux.0     #查找 pxelinux.0 文件所在目录
[root@server ~]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
# 将 pxelinux.0 复制到 TFTP 所在目录,以便客户端(需要自动安装系统的主机)通过 TFTP 能找到此加载程序。
[root@server ~]# cp /mnt/cdrom/images/pxeboot/{initrd.img,vmlinuz} /var/lib/tftpboot/
#copy 光盘目录中的 vmlinuz 和 initrd.img, 这两个文件相当于系统启动时 /boot 目录下的启动文件
[root@server ~]# mkdir -p /var/lib/tftpboot/pxelinux.cfg
[root@server ~]# cp /mnt/cdrom/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
#TFTP 目录下新建 pxelinux.cfg 的目录,将【isolinux.cfg:启动时显示配置文件信息】复制到此目录下。
[root@server ~]# cp /mnt/cdrom/isolinux/{boot.msg,splash.png} /var/lib/tftpboot/
#copy pxe 引导所需要的配置文件, splash.png: 背景图. boot.msg 启动标语, vesamenu.c32: 显示同行界面用的程序.

2.5 ks.cfg 文件的修改
注意:此文件为安装过程中自动应答文件,可将 Kickstart 的 anaconda-ks.cfg 文件为模板,也可采用图形化方式设置此文件【参考 006 笔记】。

[root@server ~]# cp /root/anaconda-ks.cfg /centosinstall/ks.cfg
[root@server /]# chmod 755 /centosinstall/ks.cfg
[root@server ~]# vi /centosinstall/ks.cfg
auth –enableshadow –passalgo=sha512
nfs –server=172.24.8.12 –dir=/centosinstall
graphical
firstboot –enable
ignoredisk –only-use=sda
keyboard –vckeymap=us –xlayouts=’us’
lang en_US.UTF-8 –addsupport=zh_CN.UTF-8   #根据需求增加语言支持
reboot
network  –bootproto=dhcp –device=eno16777736 –onboot=yes –ipv6=auto –activate
# 此项采用默认即可,测试修改网卡名为 eth0 也无法生效,依旧是 eno16777736。
network  –hostname=localhost.localdomain
rootpw –iscrypted $6$LgafQJ7F1rcyRCpk$ZteQKXvywjifMoPbAnhm7nESFx4fuROoxVYie4YvP04DGiUGpjEW2mA.m0TUQyq1ZoOUv.EF9vMWUaBjGyowW.
services –disabled=”chronyd”
timezone Asia/Shanghai –isUtc –nontp
bootloader –append=” crashkernel=auto” –location=mbr –boot-drive=sda
clearpart –all –initlabel
part /boot –fstype=”xfs” –ondisk=sda –size=300
part pv.195 –fstype=”lvmpv” –ondisk=sda –size=30419
volgroup centos –pesize=4096 pv.195
logvol /  –fstype=”xfs” –size=1 –name=root –vgname=centos –grow
logvol swap  –fstype=”swap” –size=2148 –name=swap –vgname=centos
logvol /home  –fstype=”xfs” –size=10340 –name=home –vgname=centos
%packages
@^minimal
@core
kexec-tools
%end
%addon com_RedHat_kdump –enable –reserve-mb=’auto’
%end

注意:
1:key –skip:为红帽系统跳过输入序列号过程;若为 CentOS 系列,则可以不保留此项内容;
2:reboot:必须项,也必须文中设定位置,不然安装完后无法自动重启;
3:clearpart –all –initlabel:必须项,自动选择清除所有数据,无需人为干预。

[root@server ~]# systemctl restart xinetd   #重启 tftp 服务

2.6 Kickstart 配置

[root@server ~]# chmod 755 /var/lib/tftpboot/pxelinux.cfg/default
# 将此文件赋予修改权限,默认不可修改。
[root@server ~]# vi /var/lib/tftpboot/pxelinux.cfg/default
default linux       #默认采用的启动项
timeout 1       #等待时间
label linux
  menu label ^Install CentOS 7
  kernel vmlinuz
  append ks=nfs:172.24.8.12:/centosinstall/ks.cfg initrd=initrd.img quiet
[root@server ~]# systemctl restart xinetd   #重启 tftp 服务
#timeout 1:# 选择停留时间为 1 秒
#172.24.8.12:Kickstart 服务器;
#/centosinstall:nfs 共享 Linux 镜像的目录,即 Linux 存放安装文件的路径;
#ks.cfg:Kickstart 自动应答配置文件;
# 不同服务共享 ks 写法——
HTTP Server ks=http://server_ip:port/path/kickstart_file
HTTPS Server ks=https://server_ip:port/path/kickstart_file
FTP Server ks=ftp://serverip:port/path/kickstart_file
NFS Server ks=nfs:server_ip:/path/kickstart_file

三 客户机测试
客户机开机自动安装
注意:客户机需要和服务端在同一网段,或能从服务端获取 IP 及相关文件。

 

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-21发表,共计4866字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中