1. 程式人生 > >003.Kickstart部署之HTTP架構

003.Kickstart部署之HTTP架構

一 準備

1.1 完整架構:Kickstart+DHCP+HTTP+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檔案 HTTP:共享ks.cfg、及所有光碟檔案 注意:此ks.cfg檔案和所有光碟檔案也可通過HTTP、FTP等方式共享。

1.3 DHCP等元件安裝

[[email protected]
~]# yum -y install dhcp* tftp* httpd [[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 配置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.3 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.4 HTTP配置

[[email protected] ~]# cp -r /mnt/cdrom/ /var/www/html/
[[email protected] ~]# systemctl start httpd.service
[[email protected] ~]# systemctl enable httpd.service

2.5 ks.cfg檔案的修改

注意:此檔案為安裝過程中自動應答檔案,可將Kickstart的anaconda-ks.cfg檔案為模板,也可採用圖形化方式設定此檔案【參考006筆記】。
[[email protected] ~]# cp /root/anaconda-ks.cfg /var/www/html/ks.cfg
[[email protected] ~]# chmod 755 /var/www/html/ks.cfg
[[email protected] ~]# vi /var/www/html/ks.cfg
auth --enableshadow --passalgo=sha512
url --url=http://172.24.8.12/cdrom				#修改為http目錄
graphical
firstboot --enable
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 --none --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
  menu default
 append initrd=initrd.img inst.ks=http://172.24.8.12/ks.cfg quiet
#timeout 1:#選擇停留時間為1秒
#172.24.8.12:Kickstart伺服器;
#append:HTTP共享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及相關檔案。