可参考:https://blog.51cto.com/baidu/158675
DHCP协议的工作方式:
客户端:
客户端广播查找DHCP服务器的UDP数据包,数据包的目标IP是255.255.255.255
服务器端:
服务器端在收到客户端广播的数据包后,会根据客户端的MAC地址与服务端的配置来进行操作:
1.查询服务端日志文件,如客户端之前使用过某IP,且该IP空闲,则提供该IP予客户端。
2.查询服务端配置文件,如配置文件对客户端MAC有提供特定的固定IP,则将该固定IP给予客户端。
3.如不符合上述俩项条件,则随机选取空闲的IP给予客户端,并记录
4.客户端选择接受DHCP服务器提供的网络参数,并发送一个广播数据包告知已经接受DHCP服务器的网络参数
5.服务器端向客户端回送确认的响应数据包,并告知客户端网络参数租约期限,开始租约计时间
客户端租约到期节约的俩种情况:
客户端脱机
关闭网络接口
重新启动
关机
客户端租约到期
DHCP服务器给予客户端的IP参数主要由俩种:
固定(Static)IP
动态(Dynamic)IP
Linux DHCP协议的实现程序:dhcp, dnsmasq
DHCP服务端的配置
主配置文件:
/etc/dhcp/dhcpd.conf (Centos6.x 配置文件位置,Centos5.x配置文件位于/etc/dhcpd.conf)
/usr/sbin/dhcpd
/etc/dhcp/dhcpd.conf --> /etc/rc.d/init.d/dhcpd (IPV4 配置文件)
/etc/dhcp/dhcpd6.conf --> /etc/rc.d/init.d/dhcpd6 (IPV6 配置文件)
/usr/sbin/dhcrelay
/etc/rc.d/init.d/dhcrelay dhcpvim中继器
dchpd和dhcrelay俩个进程同时只能启动一个
dhcp服务监听在udp的67号端口
dhclient: 68/udp
dhcpd.conf 范例文件:/usr/share/doc/dhcp*/dhcpd.conf.example
主配置文件/etc/dhcp/dhcpd.conf或/etc/dhcpd.conf 的语法
除了右括号")"后面之外,其他每一行配置最后都要以";"作为结尾。
某些配置项目必须以option来定义,基本形式为"option <参数代码><配置内容>"
如需分配固定IP的化,需要知道设置成固定IP的那台计算机的MAC地址
全局设置:
allow booting;允许DHCP服务器给没有安装操作系统的服务器分配IP地址
default-lease-time xxx #默认租约时间
max-lease-time xxx #最大租约时间
option routers 默认网关的IP地址 #为客户端指定默认网关的的IP地址
option domain-name-servers xxx #为客户端指定DNS地址
IP分配设置:
subnet 网络地址 netmask 子网掩码 { 设定DHCP待分配地址的区域,subnet和netmask为是关键词
range IP1 IP2 ; #指定一个连续的IP地址段
host 主机名 { 指定固定IP对应到固定MAC的设置值
hardware etherent MAC地址;
fixed-address IP地址;
}
}
对于option 定义的某配置,如果同时存在于全局配置和IP分配设置中,则作用范围越小的配置越先生效。
其它配置选项:
filename: 指明引导文件名称;
next-server:提供引导文件的服务器IP地址;
范例;
filename "pxelinux.0";
next-server 172.16.100.67;
TFTP: tftp:简单文件传输协议 监听在udp的69号端口 受xinetd服务管理
安装:
服务端 yum install tftp-server
客户端 yum install tftp
配置文件:
/etc/xinetd.d/tftp
文件访问根目录:
/var/lib/tftpboot
tftp受xinetd管理,配置文件是/etc/xinetd.d/tftp
配置文件内容如下:
service tftp
{ socket_type = dgram protocol = udp wait = yes user = root server = /usr/sbin/in.tftpd server_args = -s /var/lib/tftpboot disable = no #此项值要改为no 启动tftp per_source = 11 cps = 100 2 flags = IPv4 } ~
修改后重启xinetd服务: systemctl restart xinetd
PXE:预启动执行环境 工作于C/S的网络模式 Client通过网络从Server下载映像,并通过网络启动操作系统
PXE 依赖于dhcp,tftp,文件服务
PXE(Pre-boot Execution Environment)是由Intel设计的协议,它可以使计算机通过网络启动。协议分为client和server两端,PXE client在网卡的ROM中,当计算机引导时,BIOS把PXE client调入内存执行,并显示出命令菜单,经用户选择后,PXE client将放置在远端的操作系统通过网络下载到本地运行。
PXE协议的成功运行需要解决以下两个问题: 既然是通过网络传输,那么计算机在启动时,它的IP地址由谁来配置; 通过什么协议下载Linux内核和根文件系统 对于第一个问题,可以通过DHCP Server解决,由DHCP server来给PXE client分配一个IP地址,DHCP Server是用来给DHCP Client动态分配IP地址的协议,不过由于这里是给PXE Client分配IP地址,所以在配置DHCP Server时,需要增加相应的PXE特有配置。 至于第二个问题,在PXE client所在的ROM中,已经存在了TFTP Client。PXE Client使用TFTP Client,通过TFTP协议到TFTP Server上下载所需的文件。
PXE client在工作过程中,需要三个二进制文件:bootstrap、Linux 内核和Linux根文件系统。Bootstrap文件是可执行程序,它向用户提供简单的控制界面,并根据用户的选择,下载合适的Linux内核以及Linux根文件系统。
syslinux :提供网络引导文件,启动加载器
通过PXE安装Linux:(使用PXE服务器安装时,默认生成的配置文件的安装文件情况下) 环境准备: yum install dhcp tftp-server xinetd -y yum install syslinux -y yum install httpd -y
将当前系统(PXE服务器)root用户家目录下的anaconda-ks.cfg文件复制到httpd的根目录中,并重命名为ks.cfg cp anaconda-ks.cfg /var/www/html/ 更改ks.cfg文件的属主属组: chown apache:apache ks.cfg
将系统镜像下的所有文件复制到/var/www/html目录下:
修改ks.cfg文件,将cdrom 这行内容改为url -url=http://192.168.1.22/
cp /usr/share/syslinux/pxelinux.0 /var/lib/tftpboot 将系统镜像中images/pxeboot目录下的vmlinuz,initrd.img 复制到tftp根目录中 cp vmlinuz initrd.img /var/lib/tftpboot/ 将系统镜像中isolinux目录下的boot.msg,vesamenu.c32,splash.png复制到tftp根目录中 cp boot.msg vesamenu.c32 splash.png /var/lib/tftpboot/ 在tftp根目录中创建pxelinux.cfg目录 mkdir /var/lib/tftpboot/pxelinux.cfg 将系统镜像中isolinux目录下的isolinux.cfg文件复制到tftp根目录下pxelinux.cfg目录中,并重命名为default cp isolinux.cfg /var/lib/tftpboot/pxelinux.cfg/default 修改/var/lib/tftpboot/pxelinux.cfg/default文件,将default vesamenu.c32这行注释,并添加default linux 这行内容 (default linux 表示默认安装 label linux 指定的系统) 找到如下内容: label linux menu label ^Install CentOS 7 kernel vmlinuz append initrd=initrd.img inst.stage2=hd:LABEL=CentOS\x207\x20x86_64 quiet 将append initrd=initrd.img inst.stage2=hd:LABEL=CentOS\x207\x20x86_64 quiet这行注释,添加以下内容: append initrd=initrd.img ks=http://192.168.1.22/ks.cfg
pxelinux.0 :引导文件 vmlinuz: 内核 initrd.img : boot.msg :开机画面文件()
配置dhcp服务: 范例如下:
allow booting; allow bootp option domain-name-servers 192.168.1.1; default-lease-time 3600; max-lease-time 7200;
log-facility local7;
subnet 192.168.1.0 netmask 255.255.255.0 {
range 192.168.1.100 192.168.1.199 ;
option routers 192.168.1.108 ;
filename "pxelinux.0";
next-server 192.168.1.22; #PXE服务器地址
}