PXE 服务器环境

    操作系统RHEL 6.5

    网卡连接eth0  VMnet1

    主机名pxesvr.tarena.com

    IP地址192.168.4.5/24

    ——  关闭 iptables 防火墙、SELinux防护机制

[root@pxesvr ~]# service  iptables  stop

[root@pxesvr ~]# chkconfig  iptables  off

[root@pxesvr ~]# setenforce  0

[root@pxesvr ~]# vim  /etc/selinux/config 

SELINUX=permissive

2. PXE 客户机

    新建一台RHEL6虚拟机裸机

    内存1GB

    硬盘20GB

    光盘无

    网卡连接eth0 VMnet1

    !!!! 注意客户机与服务器应在同一物理网段并排除其他DHCP服务器的干扰

    

二搭建PXE装机服务器

1. 准备RHEL 6.5安装源以YUM源的方式提供

[root@pxesvr ~]# yum  -y  install  vsftpd //。。。安装FTP服务器

[root@pxesvr ~]# service  vsftpd  restart //启动 vsftpd 服务

[root@pxesvr ~]# chkconfig  vsftpd  on   //设置 vsftpd 服务开机自运行

[root@pxesvr ~]# cp  -rf  /misc/cd/*  /var/ftp/rhel6/   //拷贝RHEL6.4光盘中的所有文档

[root@pxesvr ~]# ls /var/ftp/rhel6/  //确认拷贝结果

[root@pxesvr ~]# vim  /etc/yum.repos.d/dvd.repo  //调整本机的YUM仓库设置以便测试

[rhel-packages]

name=RHEL 6.5 Packages

baseurl=ftp://192.168.4.5/rhel6

enabled=1

gpgcheck=1

gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

[root@pxesvr ~]# yum repolist   //确保此YUM源可用

2. 启用DNS服务

[root@pxesvr ~]# yum  -y  install bind bind-chroot

[root@pxesvr ~]# mv  /etc/named.conf  /etc/named.conf.old   //避免默认配置干扰

[root@pxesvr ~]# vim  /var/named/chroot/etc/named.conf   //DNS服务的主配置文件

options {

        directory "/var/named";

};

zone "tarena.com" IN {   //定义正向区域

        type master;

        file "tarena.com.zone";

};

zone "4.168.192.in-addr.arpa" IN {   //定义反向区域

        type master;

        file "192.168.4.arpa";

};

[root@pxesvr ~]# vim  /var/named/chroot/var/named/tarena.com.zone   //正向区域数据文件

$TTL 1D

@ SOA tarena.com.  root.tarena.com.  (

2014072101

8H

2H

4H

1D

)

@ IN NS ns.tarena.com.

ns IN A 192.168.4.5

pxesvr IN A 192.168.4.5

ftp IN CNAME pxesvr

$GENERATE  100-200 pc$ IN A 192.168.4.$

[root@pxesvr ~]# vim  /var/named/chroot/var/named/192.168.4.arpa   //反向区域数据文件

$TTL 1D

@ SOA tarena.com.  root.tarena.com.  (

2014072101

8H

2H

4H

1D

)

@ IN NS ns.tarena.com.

5 IN PTR pxesvr.tarena.com.

$GENERATE  100-200 $ IN PTR pc$.tarena.com.

[root@pxesvr ~]# service  named  restart   //启动 named 服务

。。。

[root@pxesvr ~]# chkconfig  named  on   //设置 named 服务开机自运行

[root@pxesvr ~]# vim  /etc/resolv.conf   //设置 DNS 客户端文件

search tarena.com

nameserver 192.168.4.5

[root@pxesvr ~]# host  pxesvr.tarena.com   //测试确保 DNS 解析可用

pxesvr.tarena.com has address 192.168.4.5

[root@pxesvr ~]# host  pc123.tarena.com

pc123.tarena.com has address 192.168.4.123

[root@pxesvr ~]# host  192.168.4.123

123.4.168.192.in-addr.arpa domain name pointer pc123.tarena.com.

3. 启用DHCP服务

[root@pxesvr ~]# yum  -y  install  dhcp   //安装 dhcp 服务程序

[root@pxesvr ~]# vim /etc/dhcp/dhcpd.conf

option domain-name "tarena.com";

option domain-name-servers 192.168.4.5;

default-lease-time 7200;

max-lease-time 14400;

subnet  192.168.4.0  netmask  255.255.255.0  {

    range  192.168.4.100  192.168.4.200;

    option routers 192.168.4.254;

    next-server  192.168.4.5;   #//TFTP引导服务器的地址

    filename  "pxelinux.0";   #//网卡引导文件名

}

[root@pxesvr ~]# service  dhcpd   restart   //启动 dhcpd 服务

[root@pxesvr ~]# netstat  -anptu  |  grep  dhcpd   //查看监听状态

udp        0      0 0.0.0.0:67                  0.0.0.0:*                               4095/dhcpd

[root@pxesvr ~]# chkconfig  dhcpd  on   //设置 dhcpd 服务开机自运行

4. 启用TFTP服务并提供内核、引导程序

[root@pxesvr ~]# yum  -y  install  tftp-server   //安装 TFTP 服务器程序

[root@pxesvr ~]# chkconfig  tftp  on   //将临时服务 tftp 设为启用 

[root@pxesvr ~]# service  xinetd  restart   //启用 xinetd  超级服务

[root@pxesvr ~]# netstat  -anptu  |  grep  xinetd //查看监听状态

udp        0      0 0.0.0.0:69                  0.0.0.0:*                               30426/xinetd

[root@pxesvr ~]# chkconfig  xinetd  on   //设置 dhcpd 服务开机自运行

[root@pxesvr ~]# yum  -y  install  syslinux

[root@pxesvr ~]# cp  /usr/share/syslinux/pxelinux.0  /var/lib/tftpboot/

    //拷贝引导Linux客户机的网卡启动文件

[root@pxesvr ~]# cd  /var/ftp/rhel6/p_w_picpaths/pxeboot/   //拷贝引导RHEL6客户机的内核和初始化镜像

[root@pxesvr pxeboot]# cp  vmlinuz  initrd.img  /var/lib/tftpboot/

[root@pxesvr pxeboot]# ls  /var/lib/tftpboot/   //确认 TFTP 根目录下部署的文档

initrd.img   pxelinux.0  vmlinuz

## 测试 TFTP 服务

[root@pxesvr pxeboot]# cd ~

[root@pxesvr ~]# yum  -y  install  tftp   //安装 TFTP 客户端命令

[root@pxesvr ~]# tftp  192.168.4.5  -c  get  pxelinux.0   //连接服务端测试下载文件

[root@pxesvr ~]# ls  -lh  pxelinux.0   //确认下载结果

-rw-r--r--. 1 root root 27K 7月  19 21:55 pxelinux.0

5. 为PXE安装配置启动菜单

[root@pxesvr ~]# mkdir /var/lib/tftpboot/pxelinux.cfg   //创建启动配置目录

[root@pxesvr ~]# cp  /var/ftp/rhel6/isolinux/isolinux.cfg  /var/lib/tftpboot/pxelinux.cfg/default

    //拷贝模板配置

[root@pxesvr ~]# chmod  755  /var/lib/tftpboot/pxelinux.cfg/default

[root@pxesvr ~]# vim  /var/lib/tftpboot/pxelinux.cfg/default   //修改默认启动设置

default   linux     #//默认从哪个标签引导系统

prompt 1     #//是否交互式安装

timeout 600     #//进入默认系统的等待超时单位1/10秒

label linux   #//定义名为linux的标签

        kernel  vmlinuz   #//选择此标签时需要加载的内核文件

        append  initrd=initrd.img   #//加载内核文件时附加的参数

三测试 PXE 网络装机

1. 启动一台裸客户机新建虚拟机默认会从网卡启动

    !!!! 如果是已有系统的客户机则需要调整BIOS设置将网络引导作为第一启动设备

2. 客户机启动后的基本过程

    1自动获取IP地址

    2下载 pxelinux.0 引导文件

    3读取 pxelinux.cfg/default 配置文件

    4在 boot: 后输入要安装的系统标签比如 linux进行选择直接回车或超时过均选择默认

    5根据选择结果执行相应的引导文件vmlinuz、initrd

    6加载安装向导程序进入交互式安装过程。。。

    !!!! 指定采用URL源自动获取IP地址

    !!!! 将安装源设置为  ftp://192.168.4.5/rhel6 

    !!!! 此后的安装设置、分区、软件包定制等过程与光盘安装相同

    —— 至此说明 PXE 引导及配置已成功可中止后续手动安装的验证过程

    —— 等待后续的 kickstart 无人值守安装测试

四配置 kickstart 无人值守安装

1. 准备应答文件

    找一台已装好的RHEL 6.5 模板客户机本例中可选 PXE 服务器本机

    通过 system-config-kickstart 工具创建 ks-el6.cfg 应答文件

[root@pxesvr ~]# yum  -y  install  system-config-kickstart

[root@pxesvr ~]# system-config-kickstart   //在图形桌面下运行

    !!!! 打开 /root/anaconda-ks.cfg 文件作为应答文件模板

    !!!! 基本配置指定默认语言、时区、根口令123456

    !!!! 安装方式新安装、FTP安装192.168.4.5、/rhel6

    !!!! 分区信息清除主引导记录、删除所有现存分区、初始化磁盘标签、/boot 200MB、SWAP 2GB、/  剩余空间

    !!!! 网络配置第一块网卡DHCP自动获取

    !!!! 防火墙配置禁用SELinux、禁用防火墙

    !!!! 软件包选择不安装图形桌面

    !!!! 安装后脚本从 pxesvr 自动下载并部署 YUM 客户端配置、安装并启动 httpd 网站服务

    rm  -rf  /etc/yum.repos.d/*

    wget  ftp://192.168.4.5/rhel6.repo  -O  /etc/yum.repos.d/rhel6.repo

    yum  clean  all

    yum  -y  install  httpd

    echo  "I  Love  Studying"  > /var/www/html/index.html

    /etc/init.d/httpd  start

   chkconfig  httpd  on

    !!!! 经上述调整后另存为应答文件 /opt/ks-el6.cfg

2. 在 PXE 服务器上部署应答文件、为客户机准备的YUM配置文件

[root@pxesvr ~]# cp  /opt/ks-el6.cfg  /var/ftp/   //。。。从模板客户机提交此文件

[root@pxesvr ~]# vim  /var/lib/tftpboot/pxelinux.cfg/default   //修改引导配置文件

default   linux     #//默认从哪个标签引导系统

prompt 1     #//是否交互式安装

timeout 600     #//进入默认系统的等待超时单位1/10秒

label linux   #//定义名为linux的标签

        kernel  vmlinuz   #//选择此标签时需要加载的内核文件

        append  ks=ftp://192.168.4.5/ks-el6.cfg  initrd=initrd.img       #//下载并启用自动应答文件

[root@pxesvr ~]# vim  /var/ftp/rhel6.repo 

[rhel-packages]

name=RHEL 6.5 Packages

baseurl=ftp://192.168.4.5/rhel6

enabled=1

gpgcheck=1

gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

[root@pxesvr ~]# ls /var/ftp/   //确认部署结果

ks-el6.cfg  pub  rhel6  rhel6.repo

[root@pxesvr ~]# wget  ftp://192.168.4.5/rhel6.repo   //测试下载上述两文件

[root@pxesvr ~]# wget  ftp://192.168.4.5/ks-el6.cfg

[root@pxesvr ~]# ls  -lh  rhel6.repo  ks-el6.cfg   //确认下载结果

-rw-r--r--. 1 root root 1.7K 7月  19 23:04 ks-el6.cfg

-rw-r--r--. 1 root root  145 7月  19 23:07 rhel6.repo

3. 启动一台裸客户机新建虚拟机测试无人值守安装

    !!!! 安装设置过程会自动应答免手工交互

    !!!! 等待客户机系统安装完成

4. 检查装好的客户机确认 POST 脚本设置结果

[root@pc100 ~]# ifconfig  eth0  |  grep  "inet addr"   //查看自动配置的IP地址

          inet addr:192.168.4.100  Bcast:192.168.4.255  Mask:255.255.255.0

[root@pc100 ~]# chkconfig  --list  httpd   //查看Web服务的自启动状态

httpd           0:off 1:off 2:on 3:on 4:on 5:on 6:关闭

    

[root@pc100 ~]# yum  -y  install  elinks   //确保可yum安装软件包

[root@pc100 ~]# elinks  --dump  http://127.0.0.1   //访问测试网页

I  Love  Studying