一、PXE系统装机系统构成
需要的服务
DNS服务,为客户机分配主机名
DHCP服务,分配IP地址,定位引导程序
TFTP服务,提供引导程序下载
FTP服务(或HTTP/NFS),提供yum安装源
客户机应具备的条件
网卡ROM必须支持PXE协议
主板支持网络启动
二、PXE装机过程
远程客户端计算机启动,由于BIOS设置了网卡启动,所以网卡PXE ROM中的程序被调入执行。首先,客户端在网络中寻找DHCP服务器,然后请求一个IP地址;同时DHCP服务器联系到TFTP服务器为此客户端发送一个bootstrap(引导程序)。客户端收到bootstrap(文件pxelinux.0)后执行,bootstrap会请求TFTP传送bootstrap的配置文件(pxelinux.cfg)。收到后读配置文件。根据配置文件内容和客户情况,客户端请求TFTP传送内核映象文件(vmlinuz)和根文件系统文件(initrd.img)。最后启动内核。这就是一个完整的pxe构建过程。然而要使网卡启动后再继续网络安装系统,则最后还需要FTP或http服务将系统所需安装文件放置FTP相应目录中进行传输安装。
实验拓扑:
-----PXE Server(vmnet1)-------------Client(vmnet1)------
实验一:搭建PXE Server
服务器IP为192.168.10.253,可以给192.168.10.0/24安装RHEL5.9
分别给每台客户端分配主机名,格式如下(1-100)
stationx.tarena.com 192.168.10.x
安装所需要的软件包存放在/data/iso/rhel5.9
前期准备:
1、设置网络参数
[root@localhost ~]# ifconfig eth0 | grep"inetaddr"
inet addr:192.168.10.253 Bcast:192.168.10.255 Mask:255.255.255.0
[root@localhost ~]# cat /etc/sysconfig/network
NETWORKING=yes
NETWORKING_IPV6=yes
HOSTNAME=server01.tarena.com
[root@localhost ~]# grep server01 /etc/hosts
192.168.10.253 server01.example.com server01
2、创建YUM源
[root@localhost ~]# mkdir -p /data/iso/rhel5.9
//放入rhel5.9 iso
[root@localhost ~]# cp -rpf /misc/cd/* /data/iso/rhel5.9/
3、配置YUM客户端
[root@localhost ~]# cd /etc/yum.repos.d/
[root@localhostyum.repos.d]# cprhel-debuginfo.reporhel5.9.repo
[root@localhostyum.repos.d]# cat rhel5.9.repo
[rhel-server]
name=Red Hat Enterprise Linux Server
baseurl=file:///data/iso/rhel5.9/Server
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release
实验步骤:
1、配置DHCP(给需要安装系统的主机分配ip)
[root@server01 ~]# rpm -q dhcp //检查是否安装了dhcp
package dhcp is not installed //提示没有安装
[root@server01 ~]# yum -y install dhcp //安装dhcp
[root@server01 ~]# cat /etc/dhcpd.conf //dhcp主配置文件
ddns-update-style interim;
default-lease-time 21600;
max-lease-time 43200;
optionrouters 192.168.10.254; //网关
optiondomain-name "tarena.com"; //域名
option domain-name-servers 192.168.10.253; //DNS
next-server192.168.10.253; //tftp服务器地址
filename"pxelinux.0"; //网卡引导文件名
subnet 192.168.10.0 netmask 255.255.255.0 {
range dynamic-bootp 192.168.10.1 192.168.10.100;
}
[root@server01 ~]# service dhcpd restart //开启服务
[root@server01 ~]# chkconfigdhcpd on //开机自启
[root@server01 ~]# netstat -tulnp | grep :67 //查看dhcp端口
udp 0 0 0.0.0.0:67 0.0.0.0:* 5219/dhcpd
2、配置DNS
[root@server01 ~]# rpm -q bind bind-chrootcaching-nameserver
package bind is not installed
package bind-chroot is not installed
package caching-nameserver is not installed
[root@server01 ~]# yum -y install bind bind-chrootcaching- nameserver
[root@server01 ~]# cd /var/named/chroot/etc/
[root@server01 etc]# cp -p named.caching-nameserver.confnamed.conf
[root@server01 etc]# vimnamed.conf
...
15 listen-on port 53 { 192.168.10.253; };
16 // listen-on-v6 port 53 { ::1; };
...
27 allow-query { any; };
28 allow-query-cache { any; };
...
37 match-clients { any; };
38 match-destinations { any; };
[root@server01 etc]# vim named.rfc1912.zones
...
51 zone "tarena.com" IN {
52 type master;
53 file "tarena.com.zone";
54 };
55
56 zone "10.168.192.arpa" IN {
57 type master;
58 file "10.168.192.arpa";
[root@server01 etc]# named-checkconfnamed.conf //检测语法是否出错
[root@server01 etc]# cd /var/named/chroot/var/named/
[root@server01 named]# cp -p named.localtarena.com.zone
[root@server01 named]# cattarena.com.zone
$TTL 86400
@ IN SOA localhost. root.localhost. (
2014061801 ; Serial
28800 ; Refresh
14400 ; Retry
3600000 ; Expire
86400 ) ;Minimum
IN NS server01.tarena.com.
server01 IN A 192.168.10.253
$GENERATE 1-100 station$ IN A 192.168.10.$
[root@localhost named]# cat 10.168.192.arpa
$TTL 86400
@ IN SOA localhost. root.localhost. (
2014061801 ;Serial
28800 ; Refresh
14400 ; Retry
3600000 ; Expire
86400 ) ; Minimum
IN NS server01.tarena.com.
253 IN PTR server01.tarena.com.
$GENERATE 1-100 $ IN PTR station$
[root@server01 named]# service named restart
[root@server01 named]# chkconfig named on
3、配置TFTP
[root@server01 ~]# rpm -q tftp-server
tftp-server-0.49-2
[root@server01 ~]# vim /etc/xinetd.d/tftp
...
13 server_args = -s /tftpboot //文件路径
14 disable = no //启用服务
...
[root@server01 ~]# service xinetd restart
[root@server01 ~]# chkconfigxinetd on
[root@server01 ~]# netstat -tulnp | grepxinetd
udp 0 0 0.0.0.0:69 0.0.0.0:* 5842/xinetd
[root@server01 ~]# rpm -qlsyslinux | grep pxelinux.0
/usr/share/syslinux/gpxelinux.0
/usr/share/syslinux/pxelinux.0
[root@server01 ~]# mkdir /tftpboot/pxelinux.cfg //创建目录
[root@server01 ~]# cp/data/iso/rhel5.9/isolinux/isolinux.cfg /tftpboot/pxelinux.cfg/default //改名为default
[root@server01 ~]# cp /usr/share/syslinux/pxelinux.0 /tftpboot/
[root@server01 ~]# cp /data/iso/rhel5.9/isolinux/vmlinuz /tftpboot/ //内核、镜像到TFTP根目录
[root@server01 ~]# cp/data/iso/rhel5.9/isolinux/initrd.img /tftpboot/
4、配置NFS共享
[root@localhost ~]# cat /etc/exports
/data/iso/rhel5.9 *(ro)
[root@localhost ~]# serviceportmap restart
[root@localhost ~]# servicenfs restart
[root@localhost ~]# chkconfigportmap on
[root@localhost ~]# chkconfignfs on
或者配置FTP
[root@server01 ~]# yum -y install vsftpd
[root@server01 ~]# tail -n 1 /etc/vsftpd/vsftpd.conf
anon_root=/data/iso/rhel5.9
[root@server01 ~]# servicevsftpd restart
[root@server01 ~]# chkconfigvsftpd on
在或者配置HTTP
[root@server01 ~]# yum -y install httpd
[root@server01 ~]# grepDocumentRoot/etc/httpd/conf/httpd.conf | grep -v"^#"
DocumentRoot "/data/iso/rhel5.9"
[root@server01 ~]# grep Indexes/etc/httpd/conf.d/welcome.conf
Options Indexes
[root@server01 ~]# servicehttpd restart
[root@server01 ~]# chkconfig httpd on
实验二:通过Kickstart实现无人值守安装(接着实验一)
[root@localhost ~]# yum -y installsystem-config-kickstart
操作过程见图片
在/root/ks.cfg文件中添加key --skip
[root@localhost ~]# cp /root/ks.cfg /data/iso/rhel5.9/
//将应答文件不是在客户机可以访问的位置
[root@server01 ~]# vim /tftpboot/pxelinux.cfg/default
...
10 label linux
11 kernel vmlinuz
12 appendinitrd=initrd.imgks=http://192.168.10.253/ks.cfg
//修改启动菜单文件,调用应答文件
客户端测试
BIOS-----网卡启动