002.Kickstart部署之NFS架構

木二發表於2018-12-30

一 準備

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及相關檔案。

相關文章