Kickstart部署之FTP架構

 


 

一 準備

 

1.1 完整架構:Kickstart+DHCP+VSFTP+TFTP+PXE

 

1.2 組件應用

Kickstart服務端IP:172.24.8.12
DHCP:提供客戶端IP,網關,鏡像路徑等;
TFTP:共享pxelinux.0、initrd.img、vmlinux、isolinux.cfg、boot.msg、vesamenu.c3二、splash.png文件
FTP:共享ks.cfg、及全部光盤文件
注意:此ks.cfg文件和全部光盤文件也可經過HTTP、FTP等方式共享。

 

1.3 FTP等組件安裝

[root@server ~]# yum -y install dhcp* tftp* vsftpd
[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/confi				#完全關閉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 配置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.3 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: 顯示同行界面用的程序.
#若爲6.8鏡像則splash.png格式爲jpg。
複製代碼
 

 

2.4 FTP配置

[root@server ~]# cp -r /mnt/cdrom/* /var/ftp/pub
[root@localhost ~]# systemctl start vsftpd.service
[root@localhost ~]# systemctl enable vsftpd.service
 

 

2.5 ks.cfg文件的修改

注意:此文件爲安裝過程當中自動應答文件,可將Kickstart的anaconda-ks.cfg文件爲模板,也可採用圖形化方式設置此文件【參考006筆記】。
複製代碼
[root@server ~]# cp /root/anaconda-ks.cfg /var/ftp/ks.cfg
[root@server ~]# chmod 755 /var/ftp/ks.cfg
[root@server ~]# vi  /var/ftp/ks.cfg
auth --enableshadow --passalgo=sha512
url --url=ftp://172.24.8.12/pub
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
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:必須項,自動選擇清除全部數據,無需人爲干預。
[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
  menu default
 append initrd=initrd.img inst.ks=ftp://172.24.8.12/ks.cfg quiet
#timeout 1:#選擇停留時間爲1秒
#172.24.8.12:Kickstart服務器;
#append:FTP共享Linux鏡像及ks.cfg文件的目錄,即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及相關文件。
相關文章
相關標籤/搜索