002.Kickstart部署之NFS架構
阿新 • • 發佈:2018-11-27
一 準備
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等元件安裝
[[email protected] ~]# yum -y install dhcp* tftp* rpcbind nfs-utils [[email protected] ~]# yum -y install xinetd #tftp依賴於xinetd,因此需要安裝xinetd
1.4 掛載系統光碟
[[email protected] ~]# mount /dev/sr0 /mnt/cdrom/
1.5 關閉防火牆及SELinux
[[email protected] ~]# systemctl stop firewalld.service [[email protected] ~]# systemctl disable firewalld.service [[email protected] ~]# setenforce 0 [[email protected] ~]# vi /etc/selinux/config #徹底關閉SELinux SELINUX=disabled
二 服務端的配置
2.1 配置DHCP
[[email protected] ~]# 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 [[email protected] ~]# systemctl start dhcpd.service #啟動dhcp服務 [[email protected] ~]# systemctl enable dhcpd.service #開機自動啟動
2.2 NFS配置
[[email protected] ~]# mkdir /centosinstall #建立nfs共享目錄 [[email protected] ~]# chown nfsnobody:nfsnobody /centosinstall/ #修改目錄所有者 [[email protected] ~]# vi /etc/exports /centosinstall 172.24.8.0/24(rw,sync) [[email protected] ~]# cp /mnt/cdrom/* /centosinstall/ #將光碟下所有檔案拷貝到nfs目錄下 [[email protected] ~]# systemctl start rpcbind.service [[email protected] ~]# systemctl enable rpcbind.service [[email protected] ~]# systemctl start nfs-server.service [[email protected] ~]# systemctl enable nfs-server.service
2.3 配置TFTP
[[email protected] ~]# vi /etc/xinetd.d/tftp service tftp { …… server = /usr/sbin/in.tftpd server_args = -s /var/lib/tftpboot #此為TFTP服務根目錄 disable = no #開啟TFTP …… } [[email protected] ~]# systemctl start xinetd.service #啟動xinetd,則xinetd管理的tftp也會啟動 [[email protected] ~]# systemctl enable xinetd.service #開機啟動xinetd,則xinetd管理的tftp也會啟動
2.4 TFTP檔案配置
#在TFTP目錄中指定相關PXE核心模組及相關引數 [[email protected] ~]# yum -y install syslinux #Linux引導載入程式 [[email protected] ~]# find / -name pxelinux.0 /usr/share/syslinux/pxelinux.0 #查詢pxelinux.0檔案所在目錄 [[email protected] ~]# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/ #將pxelinux.0複製到TFTP所在目錄,以便客戶端(需要自動安裝系統的主機)通過TFTP能找到此載入程式。 [[email protected] ~]# cp /mnt/cdrom/images/pxeboot/{initrd.img,vmlinuz} /var/lib/tftpboot/ #copy光碟目錄中的vmlinuz和initrd.img, 這兩個檔案相當於系統啟動時/boot目錄下的啟動檔案 [[email protected] ~]# mkdir -p /var/lib/tftpboot/pxelinux.cfg [[email protected] ~]# cp /mnt/cdrom/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default #TFTP目錄下新建pxelinux.cfg的目錄,將【isolinux.cfg:啟動時顯示配置檔案資訊】複製到此目錄下。 [[email protected] ~]# 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筆記】。[[email protected] ~]# cp /root/anaconda-ks.cfg /centosinstall/ks.cfg [[email protected] /]# chmod 755 /centosinstall/ks.cfg [[email protected] ~]# 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:必須項,自動選擇清除所有資料,無需人為干預。
[[email protected] ~]# systemctl restart xinetd #重啟tftp服務
2.6 Kickstart配置
[[email protected] ~]# chmod 755 /var/lib/tftpboot/pxelinux.cfg/default #將此檔案賦予修改許可權,預設不可修改。 [[email protected] ~]# 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 [[email protected] ~]# 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