1、簡介html
1.1 什麼是PXElinux
PXE(Pre-boot Execution Environment,預啓動執行環境)是由Intel公司開發的最新技術,工做於Client/Server的網絡模式,支持工做站經過網絡從遠端服務器下載映像,並由此支持經過網絡啓動操做系統,在啓動過程當中,終端要求服務器分配IP地址,再用TFTP(trivial file transfer protocol)或MTFTP(multicast trivial file transfer protocol)協議下載一個啓動軟件包到本機內存中執行,由這個啓動軟件包完成終端基本軟件設置,從而引導預先安裝在服務器中的終端操做系統。vim
嚴格來講,PXE 並非一種安裝方式,而是一種引導方式。進行 PXE 安裝的必要條件是在要安裝的計算機中必須包含一個 PXE 支持的網卡(NIC),即網卡中必需要有 PXE Client。PXE 協議可使計算機經過網絡啓動。此協議分爲 Client端和 Server 端,而PXE Client則在網卡的 ROM 中。當計算機引導時,BIOS 把 PXE Client 調入內存中執行,而後由 PXE Client 將放置在遠端的文件經過網絡下載到本地運行。運行 PXE 協議須要設置 DHCP 服務器和 TFTP 服務器。DHCP 服務器會給 PXE Client(將要安裝系統的主機)分配一個 IP 地址,因爲是給 PXE Client 分配 IP 地址,因此在配置 DHCP 服務器時須要增長相應的 PXE 設置。此外,在 PXE Client 的 ROM 中,已經存在了 TFTP Client,那麼它就能夠經過 TFTP 協議到 TFTP Server 上下載所需的文件了。centos
PXE的工做過程:服務器
1. PXE Client 從本身的PXE網卡啓動,向本網絡中的DHCP服務器索取IP;網絡
2. DHCP 服務器返回分配給客戶機的IP 以及PXE文件的放置位置(該文件通常是放在一臺TFTP服務器上) ;app
3. PXE Client 向本網絡中的TFTP服務器索取pxelinux.0 文件;less
4. PXE Client 取得pxelinux.0 文件後之執行該文件;dom
5. 根據pxelinux.0 的執行結果,經過TFTP服務器加載內核和文件系統 ;socket
6. 進入安裝畫面, 此時能夠經過選擇HTTP、FTP、NFS 方式之一進行安裝;
詳細工做流程,請參考下面這幅圖:
1.2 什麼是Kickstart
Kickstart是一種無人值守的安裝方式。它的工做原理是在安裝過程當中記錄典型的須要人工干預填寫的各類參數,並生成一個名爲ks.cfg的文件。若是在安裝過程當中(不僅侷限於生成Kickstart安裝文件的機器)出現要填寫參數的狀況,安裝程序首先會去查找Kickstart生成的文件,若是找到合適的參數,就採用所找到的參數;若是沒有找到合適的參數,便須要安裝者手工干預了。因此,若是Kickstart文件涵蓋了安裝過程當中可能出現的全部須要填寫的參數,那麼安裝者徹底能夠只告訴安裝程序從何處取ks.cfg文件,而後就去忙本身的事情。等安裝完畢,安裝程序會根據ks.cfg中的設置重啓系統,並結束安裝。
PXE+Kickstart 無人值守安裝操做系統完整過程以下:
2、系統環境
實驗環境:VMware Workstation 11
系統平臺:CentOS release 6.6 (基本安裝)
網絡模式:NAT模式(共享主機的IP地址)
DHCP / TFTP IP:192.168.10.20
HTTP / FTP / NFS IP:192.168.10.20
防火牆已關閉/iptables: Firewall is not running.
SELINUX=disabled
3、準備工做
生成ks.cfg 文件須要system-config-kickstart 工具,而此工具依賴於X Windows,因此咱們須要安裝X Windows 和Desktop 並重啓系統,操做以下:
安裝桌面工具
# yum groupinstall "X Window System"
# yum groupinstall Desktop
關閉iptables
# service iptables stop 中止iptables服務
# chkconfig iptables off 開機不自動啓動
# chkconfig --list |grep iptables 查看設置是否成功
關閉SElinux
# getenforce 查詢SElinux狀態
# vim /etc/selinux/config
將SELINUX=enforcing設置爲SELINUX=disabled
所有準備工做設置完成後重啓
# reboot
4、配置FTP安裝方式
系統的安裝方式能夠選擇HTTP、FTP、 NFS,咱們這裏介紹FTP方式的安裝,其餘兩種方式的安裝,你們能夠自行百度。
4.1 安裝並配置FTP
# yum install vsftpd –y 安裝FTP服務
# rpm -qa|grep vsftpd 查看安裝FTP是否成功
開啓服務並設置開機啓動
# /etc/init.d/vsftpd start 開啓FTP服務
# chkconfig vsftpd on 添加開啓就啓動
# chkconfig --list |grep vsftpd 查看是否添加開機啓動成功
4.2 加載ISO鏡像
在虛擬機中設置加載ISO鏡像。
將iso文件掛載至/mnt/cdrom.
4.3 複製光盤所有內容至ftp 的根目錄/var/ftp 下
# cp -rv /mnt/cdrom/ /var/ftp
FTP部分設置完畢。
5、配置TFTP
5.1 安裝tftp-server
# yum install tftp-server –y
5.2 啓用tftp 服務
# vi /etc/xinetd.d/tftp
# default: off
# description: The tftp server serves files using the trivial file transfer \
# protocol. The tftp protocol is often used to boot diskless \
# workstations, download configuration files to network-aware printers, \
# and to start the installation process for some operating systems.
service tftp
{
socket_type = dgram
protocol = udp
wait = yes
user = root
server = /usr/sbin/in.tftpd
server_args = -s /var/lib/tftpboot
disable = no
per_source = 11
cps = 100 2
flags = IPv4
}
將disable 設置爲no
5.3 啓動tftp服務
由於tftp服務是掛載在超級進程xinetd 下的,因此經過啓動xinetd 來啓動tftp服務。
# /etc/init.d/xinetd restart
設置開機啓動xinetd
# chkconfig xinetd on
6、配置支持PXE的啓動程序
6.1 複製pxelinux.0 文件至/var/lib/tftpboot/ 文件夾中
# cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/
若是沒有syslinux文件夾,則多是syslinux沒有安裝。則可執行下述命令進行安裝
# rpm -qa |grep syslinux 查詢是否有安裝selinux
# yum -y install syslinux 安裝selinux
說明:syslinux是一個功能強大的引導加載程序,並且兼容各類介質。更加確切地說:SYSLINUX是一個小型的Linux操做系統,它的目的是簡化首次安裝Linux的時間,並創建修護或其它特殊用途的啓動盤。
6.2 複製iso 鏡像中的/p_w_picpath/pxeboot/initrd.img 和vmlinux 至/var/lib/tftpboot/ 文件夾中
# cp /mnt/cdrom/p_w_picpaths/pxeboot/{initrd.img,vmlinuz} /var/lib/tftpboot/
6.3 複製iso 鏡像中的/isolinux/*.msg 至/var/lib/tftpboot/ 文件夾中
# cp /var/ftp/cdrom/isolinux/*.msg /var/lib/tftpboot/
6.4 在/var/lib/tftpboot/ 中新建一個pxelinux.cfg目錄
# mkdir /var/lib/tftpboot/pxelinux.cfg
6.5 將iso 鏡像中的/isolinux 目錄中的isolinux.cfg複製到pxelinux.cfg目錄中,同時更改文件名稱爲default
# cp /var/ftp/cdrom/isolinux/isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default
6.6 修改default文件
# vi /var/lib/tftpboot/pxelinux.cfg/default
default ks
prompt 1
timeout 6
display boot.msg
F1 boot.msg
F2 options.msg
F3 general.msg
F4 param.msg
F5 rescue.msg
label linux
kernel vmlinuz
append initrd=initrd.img
label vesa
kernel vmlinuz
append initrd=initrd.img text
label ks
kernel vmlinuz
append ks=ftp://192.168.10.20/ks.cfg initrd=initrd.img
label local
localboot 1
label memtest86
kernel memtest
append -
7、配置DHCP
7.1 安裝DHCP服務
# yum -y install dhcp
7.2 修改/etc/dhcp/dhcpd.conf 配置文件,內容以下:
#
# DHCP Server Configuration file.
# see /usr/share/doc/dhcp*/dhcpd.conf.example
# see dhcpd.conf(5) man page
#
#option domain-name "test.com";
log-facility local7;
allow booting; #//pexlinux 使用
allow bootp; #//pexlinux 使用
subnet 192.168.10.0 netmask 255.255.255.0 {
range 192.168.10.200 192.168.10.250; #//動態得到IP範圍
option routers 192.168.10.1; #//網關
option domain-name-servers 192.168.1.1; #DNS
default-lease-time 600; # //租用時間
max-lease-time 7200;
next-server 192.168.10.20; #//pexlinux 使用
filename "pxelinux.0"; #//pexlinux 使用
}
7.3 啓動DHCP服務
# service dhcpd configtest
Syntax: OK
# /etc/init.d/dhcpd start 啓動dhcp服務
# chkconfig dhcpd on 設置開機啓動
8、生成ks.cfg 文件
8.1 安裝Kickstart
# yum install system-config-kickstart -y
8.2 在桌面環境下配置Kickstart
啓動X Windows 環境
# startx
配置Kickstart
# system-config-kickstart
A. 設置語言,鍵盤,時區,Root密碼,安裝完畢後重啓等。
B. 設置安裝方式,這篇文章介紹的是FTP方式的安裝,故選擇FTP
C. 安裝MBR
D. 設置分區
E. 分區總覽
F. 配置網絡
G. 認證配置
H. SELinux 和防火牆配置
I. 圖形環境配置
J. 軟件包安裝選擇
K. 預覽
L. 生成ks.cfg 文件,保存在/var/ftp 文件夾下
咱們能夠打開/var/ftp/ks.cfg 文件進行查看並作修改。
#platform=x86, AMD64, or Intel EM64T
#version=DEVEL
# Firewall configuration
firewall --disabled
# Install OS instead of upgrade
install
# Use network installation
url --url="ftp://192.168.10.20/cdrom"
# Root password
rootpw --iscrypted $1$kE9gS3tg$4.hroAltH3mC3fG9AXJnl.
# System authorization information
auth --useshadow --passalgo=sha512
# Use graphical install
graphical
firstboot --disable
# System keyboard
keyboard us
# System language
lang en_US
# SELinux configuration
selinux --disabled
# Installation logging level
logging --level=info
# Reboot after installation
reboot
# System timezone
timezone --isUtc Asia/Shanghai
# Network information
network --bootproto=dhcp --device=eth0 --onboot=on
# System bootloader configuration
bootloader --location=mbr
# Clear the Master Boot Record
zerombr
# Partition clearing information
clearpart --all --initlabel
# Disk partitioning information
part / --fstype="ext4" --size=8192
part swap --fstype="swap" --size=1024
part /home --fstype="ext4" --size=2048
%packages
@base
%end
說明:key --skip 若是是紅帽系統,此選項能夠跳過輸入序列號過程;若是是CentOS 系列,則能夠不保留此項內容;
reboot 此選項必須存在,也必須文中設定位置,否則kickstart顯示一條消息,並等待用戶按任意鍵後才從新引導;
clearpart --all --initlabel 此條命令必須添加,否則系統會讓用戶手動選擇是否清除全部數據,這就須要人爲干預了,從而致使自動化過程失敗;
9、測試安裝
自動化安裝系統配置完畢,下面啓動一臺新的機器進行測試,網絡鏈接模式選擇NAT模式。
新建虛擬機,選擇自定義(高級)
選擇「稍後安裝操做系統」
選擇客戶機操做系統類型
命名虛擬機
設置此虛擬機的內存
設置網絡類型
選擇I/O控制器類型
選擇磁盤類型
選擇磁盤
指定磁盤大小,ks.cfg 文件中,咱們定義了/ 大小爲8GB,swap 分區爲1GB,/home 分區爲2GB,因此這裏的磁盤大小至少要爲12GB。
並且,必定要勾選上「當即分配全部磁盤空間」,否則在後來安裝的時候將提示沒有磁盤空間。
指定磁盤文件
虛擬機總覽
正在建立磁盤,過程會很慢,虛擬機須要產生一個20GB的文件。
啓動虛擬機,選擇從網卡啓動,DHCP 服務器正在給客戶機分配IP地址。
開始下載vmlinuz 和initrd.img
安裝過程...
安裝過程...
安裝過程...
安裝完畢,重啓後,顯示登陸界面
登陸系統查看,磁盤分區和咱們在ks.cfg 文件中設定的同樣。
PXE+Kickstart 無人值守安裝操做系統環境搭建完畢