配置与使用PXE自动化部署CentOS7

安装环境:

一台已安装Linux系统的主机作为PXE Server, 本文中PXE Server使用的系统是CentOS 7;

若干台待安装CentOS7的裸主机作为PXE Client;

PXE Server与所有PXEClient处于同一局域网中;

所有主机支持PXE启动安装方式。

 

PXEServer安装及配置流程:

1.  配置 DHCP 服务

2.  配置 TFTP 服务

3.  配置http做文件仓库和修改ks.cfg文件

4.  相关系统引导文件存储

5.  配置default系统启动文件

6.  检查PXEServer的状态并启动PXE Client

 

PXEServer安装及配置具体步骤:

1.   配置DHCP服务

安装DHCP

# yum install -y dhcp

 

当前PXE ServerIP地址为192.168.52.132DHCPTFTPhttp均部署在该台主机上,配置dhcp配置文件/etc/dhcp/dhcpd.conf如下

 

 

 

 

 

 

 

 

 

 

 

 

#

# DHCP Server Configuration file.

#   see /usr/share/doc/dhcp*/dhcpd.conf.example

#   see dhcpd.conf(5) man page

 

ddns-update-style interim;

ignore client-updates;

allow booting;

allow bootp;

 

class "pxeclients"{

        match if substring(option vendor-class-identifier,0,9)="PXEClient";

        filename "pxelinux.0";#pxe boot需要的启动文件名相当于bootloader

        next-server 192.168.52.132; #tftp serverip

}

 

subnet 192.168.52.0 netmask 255.255.255.0{

        default-lease-time 216000;

        max-lease-time 432000;

        option time-offset -18000;

        range dynamic-bootp 192.168.52.150 192.168.52.160;#地址池范围

        option subnet-mask 255.255.255.0;

        option routers 192.168.52.1;

}

 

启动并且配置开机启动dhcpd服务

# systemctl start dhcpd

# systemctl enable dhcpd

 

2.   配置TFTP服务

安装tftpserverclient

# yum install -y tftp*

安装xinetd守护进程,因为tftp依赖于xinetd

# yum install -y xinetd

 

修改tftp配置文件/etc/xinetd.d/tftp,将disable= yes改为disable=no

 

# default: off

# description: The tftp server serves filesusing the trivial file transfer

#      protocol.  The tftp protocol isoften used to boot diskless

#      workstations, download configuration files to network-aware printers,

#      and to start the installation process for some operating systems.

servicetftp

{

       socket_type            =dgram

       protocol               =udp

       wait                   =yes

       user                   =root

       server                 =/usr/sbin/in.tftpd

       server_args            =-s/var/lib/tftpboot

       disable                = on

       per_source             =11

       cps                    =1002

       flags                  =IPv4

}

 

关闭并配置开机自动关闭系统防火墙(重要!否则会导致PXE Client无法访问TFPT服务)

# systemctl stop firewalld

# systemctl disable firewalld

 

启动并配置开机自动启动xinetd进程

# systemctl start xinetd

# systemctl enable xinetd

# systemctl start thcp

 

3.   配置http做文件仓库和修改ks.cfg文件

安装httpd服务

# yum install –y httpd

 

启动并且配置开机启动httpd服务

# systemctl start httpd

# systemctl enable httpd

 

放入待安装系统盘,并直接用光盘的package当做安装仓库

# mkdir /var/www/html/centos7

# mount /dev/cdrom/var/www/html/centos7/

 

将当前系统中的ks文件拷贝到/var/www/html/路径下

# cp /root/anaconda-ks.cfg/var/www/html/ks.cfg

 

修改ks.cfg配置文件/var/www/html/ks.cfg

ks.cfg的作用是预先指定好需要的安装选项(包括系统镜像路径,安装组件,系统语言,网络配置,用户及密码等),当正式安装时PXE Client将会很据该文件去自动配置安装,从而避免了大规模部署时的大量重复操作。

 

主要修改的地方是将

# Use CDROM installation media

cdrom

修改为

# Use network installation

url --url="http://192.168.52.132/centos7"

从而指定PXE Client从哪里去获得镜像文件,ks.cfg文件修改后如下,

 

#version=DEVEL

# System authorization information

auth --enableshadow --passalgo=sha512

# Use network installation

url --url="http://192.168.52.132/centos7"

# Use graphical install

graphical

# Run the Setup Agent on first boot

firstboot --enable

# Keyboard layouts

keyboard --vckeymap=cn --xlayouts='cn'

# System language

lang zh_CN.UTF-8

 

# Network information

network --bootproto=dhcp--device=eno16777736 --ipv6=auto --activate

network --hostname=localhost.localdomain

 

# Root password

rootpw --iscrypted$6$qUeqvWWOr921mWBY$h5wjwdcnIOC/FS6rCaZblKNGELwN9jrGwJZuwlrNi9OHzI.n1lxaKKrkwdN7nadXP5f2mFRDrW9D9gYStXGZu/

# System timezone

timezone Asia/Shanghai --isUtc

user --groups=wheel --name=pxetest--password=$6$.hgpJdCAhSMaf7yB$5GKYIAgTkLxfS1JHK5KSpN96LXhkKGFX3FbnQl0hTME3wbF1njxyezmPF/HXAtI9Bp8U6MsF3hRXlFvFfn9Nm/--iscrypted --gecos="pxetest"

# System bootloader configuration

bootloader --append=" crashkernel=auto"--location=mbr --boot-drive=sda

autopart --type=lvm

# Partition clearing information

clearpart --none --initlabel

 

%packages

@^infrastructure-server-environment

@base

@compat-libraries

@core

@debugging

@development

@dns-server

@file-server

@ftp-server

@security-tools

@smart-card

kexec-tools

 

%end

 

%addon com_redhat_kdump --enable--reserve-mb='auto'

 

%end

 

关于ks.cfg的详细介绍及配置见另一篇文章《PXE配置中ks.cfg文件介绍》

 

4.   相关系统引导文件存储

安装syslinux,它是一个功能强大的引导加载程序,而且兼容各种介质。

# yum install -y syslinux

 

pxelinux.0文件名要和dhcp配置文件内的一致

# cp/usr/share/syslinux/pxelinux.0 /var/lib/tftpboot/

 

copy光盘目录中的vmlinuzinitrd.img,这两个文件相当于系统启动时/boot目录下的启动文件,这个用来引导anacoda而不是根

# cp/mnt/cdrom/images/pxeboot/{vmlinuz,initrd.img} \

/var/lib/tftpboot/

 

copy pxe引导所需要的配置文件,splash.png:背景图.boot.msg启动标语,vesamenu.c32:显示同行界面用的程序.

# cp/mnt/cdrom/isolinux/{boot.msg,vesamenu.c32,splash.png}\

 /var/lib/tftpboot/

 

pxe启动时显示配置文件信息,和光盘启动类似.

# mkdir/var/lib/tftpboot/pxelinux.cfg

# cp/mnt/cdrom/isolinux/isolinux.cfg\

 /var/lib/tftpboot/pxelinux.cfg/default

 

5.   配置default系统启动文件

default配置文件/var/lib/tftpboot/pxelinux.cfg/default中找到下面标签

 

label linux

  menu label^Install CentOS 7

  kernel vmlinuz

  menu default

  appendinitrd=initrd.img inst.stage2=http://192.168.52.132/centos7\

 inst.ks=http://192.168.52.132/ks.cfg  quiet

 

注意标红的地方,它的目的是用于告诉PXEClient去哪里可以找到镜像文件以及ks.cfg配置文件。

 

6.   检查PXE Server的状态并启动PXE Client

 

# service dhcpd status   

# service tftp status

# service httpd status

以上三者结果都应该为active(running)

 

# service firewalld status

结果都应该为inactive(dead)

 

检查待安装系统盘是否以及挂载到指定目录下(/var/www/html/centos7/

 

如果以上状态均正常,可以开始启动PXEClient,并将启动方式设置为网卡启动。

常见问题:

1、 PXE Server每次启动后IP地址都不相同?

答:应该讲PXE Server设置为静态IP,否则每次重启都需要根据新IP修改配置文件

 

2、 PXE Server重启后Client端显示连接不到TFTP服务器?

答:PXE Server每次重启后需要重新打开tftp服务

#service tftp start

 

3、 PXE Server重启后Client端显示无法访问到指定文件?

答:PXE Server每次重启后需要重新mount光盘到指定路径

你可能感兴趣的:(运维)