pxe详解

一、PXE到底是什么东东?

PXE(Preboot Execution Environment) 预启动执行环境 是由Intel设计的协议,它可以使计算机通过网络启动。协议分为client和server两端,PXE client在网卡的ROM中,当计算机引导时,BIOS把PXE client调入内存执行,并显示出命令菜单,经用户选择后,PXE client将放置在远端的操作系统通过网络下载到本地运行。

既然是通过网络传输,就需要IP地址;也就是说在其启动过程中,客户端请求服务器分配IP地址,之后PXE Client使用TFTP Client 通过TFTP(Trivial File Transfer Protocol)协议下载启动安装程序所需的文件。

简单地说PXE网络安装,客户机通过支持PXE的网卡向网络中发送请求DHCP信息的广播请求IP地址等信息,DHCP服务器给客户端提供IP地址和其它信息(TFTP服务器、启动文件等),之后请求并下载安装需要的文件。在这个过程中需要一台服务器来提供启动文件、安装文件、以及安装过程中的自动应答文件等。

二、pxe工作过程

下图中介绍了Linux中自动安装系统的详细工作过程:

第一步:PXE Client向DHCP发送请求

首先,将支持PXE的网络接口卡(NIC)的客户端的BIOS设置成为网络启动,通过PXE BootROM(自启动芯片)会以UDP(简单用户数据报协议)发送一个广播请求,向网络中的DHCP服务器索取IP地址等信息。

第二步:DHCP服务器提供信息

DHCP服务器收到客户端的请求,验证是否来至合法的PXE Client的请求,验证通过它将给客户端一个提供“响应”,这个提供“响应”中包含了为客户端分配的IP地址、pxelinux启动程序(TFTP)位置,以及配置文件所在位置。

第三步:PXE客户端请求下载启动文件

客户端收到服务器的“回应”后,会回应一个帧,以请求下载启动所需文件。

这些启动文件包括:pxelinux.0、pxelinux.cfg/default、vmlinuz、initrd.img等文件。

第四步:Boot Server响应客户端请求并传送文件

当服务器收到客户端的请求后,他们之间之后将有更多的信息在客户端与服务器之间作应答, 用以决定启动参数。BootROM 由 TFTP 通讯协议从Boot Server下载启动安装程序所必须的文件(pxelinux.0、pxelinux.cfg/default)。default文件下载完成后,会根据该文件中定义的引导顺序,启动Linux安装程序的引导内核。

第五步:请求下载自动应答文件

客户端通过pxelinux.cfg/default文件成功的引导Linux安装内核后,安装程序首先必须确定你通过什么安装介质来安装linux,如果是通过网络安装(NFS, FTP, HTTP),则会在这个时候初始化网络,并定位安装源位置。或许你会说,刚才PXE不是已经获取过IP地址了吗?为什么现在还需要一次?这是由于PXE获取的是安装用的内核以及安装程序等,而安装程序要获取的是安装系统所需的二进制包以及配置文件。由于它们需要的内容不同造成PXE模块和安装程序是相对独立的,PXE的网络配置并不能传递给安装程序。从而进行两次获取IP地址过程。

接着会读取该文件中指定的自动应答文件ks.cfg所在位置,根据该位置请求下载该文件。

第六步:客户端安装操作系统

将ks.cfg文件下载回来后,通过该文件找到OS Server,并按照该文件的配置请求下载安装过程需要的软件包。OS Server和客户端建立连接后,将开始传输软件包,客户端将开始安装操作系统。

安装完成后,将提示重新引导计算机。这个时候注意,在重新引导的过程中一定要将BIOS修改回从硬盘启动,不然的话又会重复的自动安装操作系统。

注意:在上面介绍中PXE client是需要安装Linux的计算机,DHCP Server、TFTP Server、和NFS Server运行在另外一台Linux Server上。Bootstrap文件、配置文件、Linux内核都放置在Linux Server上TFTP服务器的根目录下。而Linux根文件系统存放于NFS Server的共享目录中。

PXE client在工作过程中,需要三个二进制文件:bootstrap、Linux 内核和Linux根文件系统。Bootstrap文件是可执行程序,它向用户提供简单的控制界面,并根据用户的选择,下载合适的Linux内核以及Linux根文件系统。

三、DHCP是什么?

dhcp:dynamic host configuration protocol(动态主机配置协议)是一个局域网网络协议,使用UDP协议工作。

dhcp提供的信息包括:

ip,netmask,gateway,dns server,dns search domain(搜索域名),nis server ,lease time(租约期限)

主要有两个用途:给内部网络或网络服务供应商自动分配IP地址,给用户或者内部网络管理员作为对所有计算机作中央管理的手段,在RFC 2131中有详细的描述。DHCP有3个端口,其中UDP67和UDP68为正常的DHCP服务端口,分别作为DHCP Server和DHCP Client的服务端口;546号端口用于DHCPv6 Client,而不用于DHCPv4,是为DHCP failover服务,这是需要特别开启的服务,DHCP failover是用来做“双机热备”的。

C/S架构

dhcp客户端第一次获取IP过程:广播

Client:dhcpdiscover

Server:dhcpoffer

Client:dhcprequest

Server:dhcpack

续租:单播(租约达到一半即需要续租)

50%--》75%--》87.5%--》93.75

客户端租约达到一半时向服务器续租,没响应时再过50%再次向服务器续租

续租成功:

dhcprequest--》dhcpack

续租失败:

dhcprequest-->dhcpnack

169.254.x.x

客户端获取Ip失败后,自动配置的Ip

路由器隔离DHCP报文,此时可以配置dhcp中继服务器

四、tftp是什么?

     TFTP(Trivial File Transfer Protocol,简单文件传输协议)是TCP/IP协议族中的一个用来在客户机与服务器之间进行简单文件传输的协议,提供不复杂、开销不大的文件传输服务。端口号为69。

       TFTP是一个传输文件的简单协议,它基于UDP协议而实现,但是我们也不能确定有些TFTP协议是基于其它传输协议完成的。此协议设计的时候是进行小文件传输的。因此它不具备通常的FTP的许多功能,它只能从文件服务器上获得或写入文件,不能列出目录,不进行认证,它传输8位数据。

传输中有三种模式:

netascii,这是8位的ASCII码形式,

另一种是octet,这是8位源数据类型;

最后一种mail已经不再支持,它将返回的数据直接返回给用户而不是保存为文件。

五、构建pxe环境

1、安装DHCP服务

1)环境

CentOS6.5-x86_64

node1:    Server

eth0 192.168.100.179

eth1 192.168.200.1

node2:    Client

2)安装dhcp

[[email protected] network-scripts]# yum install dhcp -y
[[email protected] network-scripts]# rpm -ql dhcp
/etc/dhcp
/etc/dhcp/dhcpd.conf
/etc/dhcp/dhcpd6.conf     # ipv6
/etc/openldap/schema/dhcp.schema
/etc/portreserve/dhcpd
/etc/rc.d/init.d/dhcpd
/etc/rc.d/init.d/dhcpd6
/etc/rc.d/init.d/dhcrelay  # dhcp中继
/etc/sysconfig/dhcpd
/etc/sysconfig/dhcpd6
/etc/sysconfig/dhcrelay
/usr/bin/omshell
/usr/sbin/dhcpd
/usr/sbin/dhcrelay
/usr/share/doc/dhcp-4.1.1

3)配置dhcp

[[email protected] network-scripts]# cd /etc/dhcp/
[[email protected] dhcp]# ls
dhclient.d  dhclient-eth0.conf  dhcpd6.conf  dhcpd.conf       
[[email protected] dhcp]# vi dhcpd.conf 

  1 #
  2 # DHCP Server Configuration file.
  3 #   see /usr/share/doc/dhcp*/dhcpd.conf.sample
  4 #   see ‘man 5 dhcpd.conf‘
  5 #
[[email protected] dhcp]# cp /usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample /etc/dhcp/dhcpd.conf
cp:是否覆盖"/etc/dhcp/dhcpd.conf"? y

dhcp配置文件详解:

[[email protected] dhcp]# cat dhcpd.conf 
# dhcpd.conf
#
# Sample configuration file for ISC dhcpd
#

# option definitions common to all supported networks...
option domain-name "example.org";        #搜索域名 (全局)
option domain-name-servers ns1.example.org, ns2.example.org;  #DNS服务器 (全局)

default-lease-time 600;     #默认租约期限
max-lease-time 7200;        #最大租约期限
# Use this to enble / disable dynamic dns updates globally.
#ddns-update-style none;

# If this DHCP server is the official DHCP server for the local
# network, the authoritative directive should be uncommented.
#authoritative;

# Use this to send dhcp log messages to a different log file (you also
# have to hack syslog.conf to complete the redirection).
log-facility local7;         #日志记录

# No service will be given on this subnet, but declaring it helps the 
# DHCP server to understand the network topology.

subnet 10.152.187.0 netmask 255.255.255.0 {   #标记一个为其分配ip地址的网络  (例1)
}

# This is a very basic subnet declaration.

subnet 10.254.239.0 netmask 255.255.255.224 {       (例2)  
  range 10.254.239.10 10.254.239.20;        #ip地址池范围
  option routers rtr-239-0-1.example.org, rtr-239-0-2.example.org;  #设置网关
}

# This declaration allows BOOTP clients to get dynamic addresses,
# which we don‘t really recommend.

subnet 10.254.239.32 netmask 255.255.255.224 {      (例3)
  range dynamic-bootp 10.254.239.40 10.254.239.60;
  option broadcast-address 10.254.239.31;
  option routers rtr-239-32-1.example.org;
}

# A slightly different configuration for an internal subnet.
subnet 192.168.200.0 netmask 255.255.255.0 {    (例4,这个例子最详细了,真正配置时可以把前面的例子都删掉,修改这个例子)
  range 192.168.200.21 192.168.200.100;
 # option domain-name-servers ns1.internal.example.org;
 # option domain-name "internal.example.org";
  option routers 192.168.200.1;
   # option broadcast-address 10.5.5.31;
  default-lease-time 600;
  max-lease-time 7200;

 next-server 192.168.200.1;   
 filename "pxelinux.0";    #告诉客户端接下来去这个服务器下载这个文件 
  
  }

配置好后,启动dhcp服务:

[[email protected] dhcp]# service dhcpd start
正在启动 dhcpd:                                           [确定]
[[email protected] dhcp]# netstat -nlptu
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      1110/sshd           
tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1198/master         
tcp        0      0 127.0.0.1:6012              0.0.0.0:*                   LISTEN      31964/sshd          
tcp        0      0 0.0.0.0:3306                0.0.0.0:*                   LISTEN      9271/mysqld         
udp        0      0 0.0.0.0:67                  0.0.0.0:*                               32106/dhcpd

使用客户机测试:
配置客户机从dhcp服务器获取ip,如果能正确获取到192.168.200.21-100段的ip说明

在服务器端查看租约信息:

[[email protected] dhcp]# cat /var/lib/dhcpd/dhcpd.leases
# The format of this file is documented in the dhcpd.leases(5) manual page.
# This lease file was written by isc-dhcp-4.1.1-P1

server-duid "\000\001\000\001\036!\014(\000\014)S\3663";

lease 192.168.200.21 {
  starts 4 2016/01/07 11:48:51;
  ends 4 2016/01/07 11:58:51;
  cltt 4 2016/01/07 11:48:51;
  binding state active;
  next binding state free;
  hardware ethernet 00:0c:29:f9:cb:14;
}
lease 192.168.200.21 {
  starts 4 2016/01/07 11:52:49;
  ends 4 2016/01/07 12:02:49;
  cltt 4 2016/01/07 11:52:49;
  binding state active;
  next binding state free;
  hardware ethernet 00:0c:29:f9:cb:14;
}

为特定主机分配特定ip:

 host passacaglia {          #定义一个名字标记
    hardware ethernet 0:0:c0:5d:bd:95;  #指定MAC地址
  #  filename "vmunix.passacaglia";
  # server-name "toccata.fugue.com";
    fixed-address 192.168.200.110;     #分别固定ip地址,此地址不能是地址池里的地址,优先级高于地址池分配地址
    }

2、安装tftp服务

时间: 2024-10-27 07:49:06

pxe详解的相关文章

PXE 详解

PXE:全称为PrebooteXecution Environment ,可以基于网络给服务器安装系统,需要网卡支持网络启动引导, 一:需要准备的组件如下: Yum install     xinetd  dhcpd   tftp-server httpd   syslinux 1.TFTP服务器:为客户端提供简单文件共享服务,比如启动内核.配置文件等等 2.DHCP服务器,作用为给客户端提供IP地址.掩码.网关.DNS.指定TFTP服务器地址 3.FTP或HTTP服务器,主要共享ks.cfg文

PXE的概述及Linux使用详解

PXE的概述及使用详解 现在企业采购的很多计算机都是没光驱的,怎么安装系统呢?另外,如何能快速大规模安装Linux服务器操作系统呢,有什么好办法吗? 答案是有的,那就是本文要说的:PXE PXE(preboot execute environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统,在启动过程中,终端要求服务器分配IP地址,再用TFTP(trivial filet

PXE 装机详解

PXE 装机详解 =========================================================================== 概述: 在实际工作中,我们经常会遇到这样的情况:想要安装Linux但是计算机没有光驱,或者是有大批量的计算机需要同时安装Linux,如果通过光驱的方式一个个安装,不仅效率低,也不利于维护.这是时候你就需要PXE的强大功能了.本文就将讲解利用PXE自动化安装CentOS6和CentOS7的安装过程. ===============

kickstart安装系统原理详解

前言 作为中小公司的运维,经常会遇到一些机械式的重复工作,例如:有时公司同时上线几十甚至上百台服务器,而且需要我们在短时间内完成系统安装. 常规的办法有什么? 光盘安装系统===>一个服务器DVD内置光驱百千块,百台服务器都配光驱就浪费了,因为一台服务器也就开始装系统能用的上,以后用的机会屈指可数.用USB外置光驱,插来插去也醉了. U盘安装系统===>还是同样的问题,要一台一台服务器插U盘. 网络安装系统(ftp,http,nfs) ===>这个方法不错,只要服务器能联网就可以装系统了

cobbler系统安装详解

现在都知道运维自动化的重要性,尤其是对于在服务器数量按几百台.几千台增加的公司而言,单单是装系统,如果不通过自动化来完成,根本是不可想象的. 运维自动化安装方面,早期一般使用人工配置pxe+dhcp+tftp配合kickstart,现在开源工具就多了,如cobbler,OpenQRM和Spacewalk.本文是我自己试验整理的Cobbler系统安装详解.       Cobbler是一个快速网络安装linux的服务,而且在经过调整也可以支持网络安装windows.该工具使用python开发,小巧

自动化运维平台之系统自动化安装Cobbler系统使用详解

一.简介 Cobbler是一个快速网络安装linux的服务,而且在经过调整也可以支持网络安装windows.该工具使用python开发,小巧轻便(才15k行python代码),使用简单的命令即可完成PXE网络安装环境的配置,同时还可以管理DHCP.DNS.以及yum仓库.构造系统ISO镜像. Cobbler支持命令行管理,web界面管理,还提供了API接口,可以方便二次开发使用. Cobbler客户端Koan支持虚拟机安装和操作系统重新安装,使重装系统更便捷. 二.cobbler提供的功能 使用

详解DHCP服务安装与管理

DHCP服务安装与管理 一.DHCP是什么 名称:DHCP – Dynamic Host Configuration Protocol 动态主机配置协议 功能:DHCP(Dynamic Host Configuration Protocol,动态主机配置协议)是一个局域网的网络协议,使用UDP协议工作, 主要有两个用途: 1. 给内部网络或网络服务供应商自动分配IP地址,主机名,DNS服务器,域名 2. 配和其它服务,实现集成化管理功能.如:无人执守安装服务器 DHCP是一个C/S架构的协议,D

53 kvm及libvirt、使用virsh管理kvm虚拟机、网络虚拟化技术基础、网络名称空间netns用法详解

01 kvm及libvirt [[email protected] ~]# yum install libvirt libvirt-client python-virtinst virt-manager virt-install -y [[email protected] ~]# yum -y install qemu-kvm [[email protected] ~]# systemctl start libvirtd.service #创建桥 [[email protected] ~]# v

Centos6上安装cobbler及cobbler常见参数详解

前言 Cobbler是一个自动化和简化系统安装的工具,通过使用网络引导来控制和启动安装.Cobbler的特性包括存储库镜像.Kickstart模板和连接电源管理系统.使用Cobbler之前需要先了解下PXE和Kickstart的基本原理,文章包含了Cobbler工作原理和Cobbler部署实践两部分内容,交叉关联性的内容还是蛮多的,遇到报错也不要怕,都会一步一步解决的. 使用Cobbler轻松设置和管理网络安装环境 Cobbler工作原理 Cobbler由Python语言开发,是对PXE和Kic