centos7 PXE自动安装环境搭建

原理:


要进行自动安装的主机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服务:

提供地址:192.168.56.0/24内分配192.168.56.20-254

提供pxe启动服务器文件地址 : 192.168.56.6 pxelinux.0

tftp服务:

提供pxe文件、引导文件(含图形界面),tftp服务器在数据目录/var/lib/tftpboot/提供pxelinux.0文件和centos7安装光盘上的相关文件

.

├── 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服务是否正常

dhclient -d 192.168.56.6

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

tftp 192.168.56.6 -c get pxelinux.0

测试软件包库地址:

elinks http://192.168.56.6/centos/7/iso/x86_86

测试kickstart文件地址:

elinks http://192.168.56.6/centos/7/iso/ks_c7_x86_64.cfg

主机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,说明成功了。

来自为知笔记(Wiz)