原理:


   要进行自动安装的主机A,加电启动时以网卡为第一启动设备

   1.启动时会向网络广播,找到dhcp服务器B请求分配IP地址信息,服务器B除了给其分配基本的IP信息(ip、netmask、geteway、dns、domain,主要为前2者),并给出pxe引导文件地址

   2.主机B根据A提供的pxe相关文件的tftp地址下载这些文件然后启动这个引导装载器(为什么用tftp而不用ftp因为前者是后者的精简版,访问资源不用用户认证!!)

   3.主机B在引导装载器的命令行交互模式中告诉其kickstart文件的http地址,由引导装载器下载此文件 (本文将该ks地址写入到引导装载器的配置文件中,从而略去命令行的交互)

   4.引导装载器根据kickstart上提供的主机安装步骤以及centos7安装包所在的http地址来完成自动安装


实验环境:


1.CentOS7光盘镜像一张

2.主机A(centos7)、B(centos6或7)、C(centos7)位于同一网络中


主机A:192.168.56.6

dhcp服务:

tftp服务:

.

├── boot.msg

├── initrd.img

├── pxelinux.0

├── pxelinux.cfg

│   └── default

├── splash.jpg

├── vesamenu.c32

└── vmlinuz

http服务

       提供软件包库: centos7安装盘的内容放在/var/www/html/centos/7/iso/x86_86

       提供kickstart文件: ks文件放在/var/www/html/centos/7/iso/ks_c7_x86_64.cfg


主机B:192.168.56.12

    负责验证主机A上的网络服务是否正常

测试dhcp服务是否正常

    测试pxe引导文件是否能下载

    测试软件包库地址:

    测试kickstart文件地址:

主机C:要进行自动安装centos7的主机



实验步骤:


一、主机A的环境准备


1.关闭selinux服务和防火墙服务

# grep "^SELINUX=" /etc/selinux/config 

SELINUX=disabled

# systemctl disable firewalld

# systemctl stop firewalld


2.设置yum源,以便安装其他服务软件

# cat /etc/yum.repos.d/CentOS-dvd.repo 

[dvd]

name=CentOS-7 - dvd

baseurl=file:///media/dvd

gpgcheck=1

enabled=1

gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

# tail -1 /etc/fstab 

/dev/cdrom /media/dvd iso9660 defaults,ro 0 0

在第一个的光驱插入centos7的安装盘,然后执行

# mount -a

如下看到挂载已成功

# mount | grep /media

/dev/sr0 on /media/dvd type iso9660 (ro,relatime)


二、主机A搭建DHCP服务,并用主机客户端B测试


a.安装和配置DHCP
# yum -y install dhcp
# vim /etc/dhcp/dhcpd.conf
# cat /etc/dhcp/dhcpd.conf
##########################dhcpd.conf文件开始##########################
#设置客户端的搜索域名,也就是/etc/resolv.conf中的search指令
option domain-name "tangsw.comg";
#设置客户端的DNS
option domain-name-servers 192.168.56.6, 192.168.56.11;
#IP地址的最小、大租约时间
default-lease-time 600;
max-lease-time 7200;
#日志设置
log-facility local7;
#给客户端分配的地址段,以及指定客户机从哪个地址下载pxe文件来启动引导装载器
subnet 192.168.56.0 netmask 255.255.255.0 {
  range 192.168.56.20 192.168.56.254;
  option routers 192.168.56.6;
  next-server 192.168.56.6;
  filename "pxelinux.0";
}
##########################dhcpd.conf文件开始##########################

b.启动并设置开机启动
# systemctl start dhcpd
# systemctl enable dhcpd

c.用主机B验证能否从服务器A获取IP租约信息
[root@localhost ~]# yum install -y dhclient
[root@localhost ~]# dhclient -d eth0
Internet Systems Consortium DHCP Client 4.1.1-P1
Copyright 2004-2010 Internet Systems Consortium.
All rights reserved.
For info, please visit https://www.isc.org/software/dhcp/

Listening on LPF/eth0/08:00:27:85:73:30
Sending on   LPF/eth0/08:00:27:85:73:30
Sending on   Socket/fallback
DHCPREQUEST on eth0 to 255.255.255.255 port 67 (xid=0x4b5bbd38)
DHCPACK from 192.168.56.6 (xid=0x4b5bbd38)
bound to 192.168.56.104 -- renewal in 277 seconds.
^C
从输出的信息可以看到eth0能从192.168.56.6获取到IP 192.168.56.104

三、主机A上tftp服47务的安装,准备tftp要提供文件,以及主机B客户端测试、主机C测试
1. 安装tftp,tftp是依赖于超级守护进程xinetd的,由xinetd负责管理tftp的启动和运行
# yum -y install tftp-server
...........(略去).........
================================================================================
 Package             Arch           Version                   Repository   Size
================================================================================
Installing:
 tftp-server         x86_64         5.2-11.el7                dvd          44 k
Installing for dependencies:
 xinetd              x86_64         2:2.3.15-12.el7           dvd         128 k
...........(略去).........
tftp的配置文件以及数据文件路径
# rpm -ql tftp-server | egrep "^(/etc|/var)"
/etc/xinetd.d/tftp
/var/lib/tftpboot

2.设置xinetd和tftp开机启动
# systemctl enable xinetd
# systemctl start xinetd
# vim /etc/xinetd.d/tftp 
# grep disable /etc/xinetd.d/tftp 
 disable = no

3..准备pxelinux.0 (来自syslinux包)
# yum -y install syslinux
# rpm -ql syslinux | grep '/pxelinux.0'
/usr/share/syslinux/pxelinux.0
# cd /var/lib/tftpboot/
[root@c7 tftpboot]# cp /usr/share/syslinux/pxelinux.0 .

4.准备pxe引导相关的引导装载器
[root@c7 tftpboot]# mkdir pxelinux.cfg
[root@c7 tftpboot]# cp /media/dvd/images/pxeboot/{initrd.img,vmlinuz} .
[root@c7 tftpboot]# cp /media/dvd/isolinux/{boot.msg,vesamenu.c32,splash.png} .
[root@c7 tftpboot]# cp /media/dvd/isolinux/isolinux.cfg pxelinux.cfg/default
[root@c7 tftpboot]# vim /media/dvd/isolinux/isolinux.cfg pxelinux.cfg/default
label linux
  menu label ^Install CentOS 7
  kernel vmlinuz
  append initrd=initrd.img inst.ks=http://192.168.56.6/centos/7/iso/ks_c7_x86_64.cfg ip=dhcp
#  append initrd=initrd.img inst.stage2=hd:LABEL=CentOS\x207\x20x86_64 quiet ,上一行对本行(源文件)做了修改,告诉引导装载器从哪里下载ks文件进行自动安装。

5.通过工具tftp测试客户端B能否正常访问服务器A上的tftp服务
注意:客户端要关闭防火墙,否则可能tftp能连接上去但是下载不了文件
[root@localhost ~]# yum -y install tftp
[root@localhost ~]# tftp 192.168.56.6 -c get pxelinux.0
如果pxelinux.0文件能下载,则表示TFTP服务正常

6.测试主机c能否正常通过网络引导(主机A上提供的DHCP以及TFTP)
设置主机c的网卡设备为第一启动设备,加电开机,如果能看到安装引导界面则表示DHCP、TFTP服务正常,并且用于pxe引导的文件部署正常。


四、主机A上http服务的安装,部署安装源,部署kickstart文件,以及主机B客户端测试、主机C测试
1.安装httpd服务,设置开机启动,启动该服务
# yum -y install httpd
# systemctl enable httpd
ln -s '/usr/lib/systemd/system/httpd.service' '/etc/systemd/system/multi-user.target.wants/httpd.service'
# systemctl start httpd

2.在httpd服务上部署pxe安装的安装包库
# mkdir -p  /var/www/html/centos/7/iso/x86_64
# vim /etc/fstab 
# tail -2 /etc/fstab 
/dev/cdrom /media/dvd iso9660 defaults,ro 0 0
/media/dvd /var/www/html/centos/7/iso/x86_64 none bind,ro 0 0
# mount -a
关盘镜像先挂载在/media/dvd作为服务器A的yum源,再通过该目录绑定到A的httpd目录,作为pxe自动安装的安装包,一举两得
在测试换

3.通过工具elinks,让客户端B测试服务器A上所部署的安装源是否正常
[root@localhost ~]# yum -y install elinks  
[root@localhost ~]# elinks http://192.168.56.6/centos/7/iso/x86_64 

4.在httpd服务上部署kickstart文件
# yum -y install system-config-kiskstart
# system-config-kiskstart &
如果是用xshell之类的远程登录工具,则需要配置才能显示system-config-kiskstart命令弹出的窗口,否则在A的桌面环境执行该命令。
在这个kickstart文件创建的程序中导入/root/anacodor-ks.cfg,基于这个文件来修改,然后将修改后的文件放到http的目录,保存路径为/var/www/html/centos/7/iso/ks_c7_x86_64.cfg,并用ksvalidator校验语法是否正确
# ksvalidator /var/www/html/centos/7/ks_c7_x86_64.cfg
# cat /var/www/html/centos/7/ks_c7_x86_64.cfg
##########################ks_c7_x86_64.cfg文件开始##########################
[root@c7 iso]# cat /var/www/html/centos/7/iso/ks_c7_x86_64.cfg
#platform=x86, AMD64, or Intel EM64T
#version=DEVEL
# Install OS instead of upgrade
install
# X Window System configuration information
xconfig  --startxonboot
# Keyboard layouts
# old format: keyboard us
# new format:
keyboard --vckeymap=us --xlayouts='us'
# Reboot after installation
reboot
# Root password
rootpw --iscrypted $1$KHH8cH8b$1O7rrwphchrB2AE0GGku/0
# System timezone
timezone Asia/Shanghai --isUtc
# Use network installation
url --url="http://192.168.56.6/centos/7/iso/x86_64"
repo --name="CentOS" --baseurl="http://192.168.56.11/centos/6/iso/x86_64" --cost=100 
# System language
lang en_US
# Firewall configuration
firewall --disabled
# Network information。如果根据安装主机的网卡数来重复指令的次数很可能安装不了
network  --bootproto=dhcp --device=link
# System authorization information
auth  --useshadow  --passalgo=sha512
# Use graphical install
graphical
# Run the Setup Agent on first boot
firstboot --enable
# SELinux configuration
selinux --disabled

ignoredisk --only-use=sda
# System bootloader configuration
bootloader --append="crashkernel=auto" --location=mbr --boot-drive=sda
autopart --type=lvm
# Clear the Master Boot Record
zerombr
# Partition clearing information
clearpart --all --initlabel 

%packages
@base
@core
@desktop-debugging
@dial-up
@directory-client
@fonts
@gnome-desktop
@guest-agents
@guest-desktop-agents
@input-methods
@internet-browser
@java-platform
@multimedia
@network-file-system-client
@networkmanager-submodules
@print-client
@x11
kexec-tools

%end

##########################ks_c7_x86_64.cfg文件结束##########################


5.通过工具elinks,让客户端B测试服务器A上所部署的安装源是否正常

[root@localhost ~]# elinks http://192.168.56.6/centos/7/iso/ks_c7_x86_64.cfg


验证



将主机C在bios设置第一启动设备为网卡,开机后显示引导界面,选择"Install CentOS 7",按enter,如果能自动安装centos7,说明成功了。