TCP/IP协议(6): DHCP(Dynamic Host Configuration Protocol) 协议 —— 网络地址的分配方式
TCP/IP协议(6): DHCP(Dynamic Host Configuration Protocol) 协议 —— 网络地址的分配方式
关于 DHCP(DHCP, Dynamic Host Configuration Protocol) 协议
我们知道 IP 协议需要参与通信的网络设备接口具有 IP 地址。一个局域网会经常接入新的主机,而接入局域网的主机也可能随时离开该局域网,这就让人工手动的分配 IP 地址几乎成为了不可能。DHCP 协议就是解决动态分配 IP 地址的应用层协议。
动态主机配置协议(DHCP, Dynamic Host Configuration Protocol) 是一种基于 UDP/IP 网络的网络管理协议。DHCP 服务器动态的分配 IP 地址和其他网络配置参数给网络中的每个设备,以使它们可以跟其他的 IP 网络通信。
(The Dynamic Host Configuration Protocol (DHCP) is a network management protocol used on UDP/IP networks whereby a DHCP server dynamically assigns an IP address and other network configuration parameters to each device on a network so they can communicate with other IP networks.)
DHCP 协议的基本内容
- 初始状态: 在如下图的局域网中,新加入 主机 H1。
- DHCP Discovery:主机 H1 发现自己没有 IP 地址,就会用 0.0.0.0:68 作为自己的地址,发送 DHCPDISCOVER 消息到广播地址 255.255.255.255:67,以发现可用的 IP 地址。
- DHCP Offer:主机 H1 广播的 DHCPDISCOVER 消息在整个局域网内传输,“看不懂”的网络设备(如,图中的主机 H2 和主机 H3)就直接将收到的包丢弃。DHCP 服务器 收到该消息后,就会从自己的 IP 地址池中取出一个 IP 地址提供给 主机 H1,并通过广播告诉主机 H1。如图中的 DHCP 服务器 S1 和 DHCP 服务器 S2 都从自己的 IP 地址池中取出一个 IP 地址(IP1 和 IP2),提供 Offer 给主机 H1。
- 主机 H1 接收到 DHCP 服务器 S1 提供的 IP1 的 Offer 和 DHCP 服务器 S2 提供的 IP2 的 Offer 。它会选择自己感兴趣的地址,如 IP1,发送请求该 IP 地址 的消息。
- DHCP Request: 主机 H1 选择接收 DHCP 服务器 S1 提供的 IP1 的 Offer。它将会在网络广播对 IP1 的 DHCPREQUEST 请求。
- DHCP Acknowledgement:当 DHCP 服务器 S2 接收到主机 H1 接收 服务器 S1 的提供的 IP1 的 DHCPREQUEST 消息时,将自己提供的 IP2 放入地址池,等待其他网络设备请求。而 主机 H1 接收到 DHCPREQUEST 消息 后,确认主机 H1愿意接收自己提供的 IP1。此时如果 IP1 没有分配出去,则将主机 H1 绑定 IP1,并回复一个 DHCOACK 消息给 主机 H1。
DHCP 中继(relaying)
一般来讲,在简单网络中,一个 DHCP 服务器供同一局域网中的网络设备使用。但在某些复杂情况下,一个 DHCP 服务器 可能为多个子网提供服务,而由于此时请求 DHCP 服务的主机还没有分配 IP 地址,因此需要 DHCP 中继代理向各局域网转发 DHCP 消息。
通常情况下,DHCP 中继代理不会参与客户机与服务器之间所有的 DHCP 流量交换。而是中继那些广播消息。
租约(lease)
通常情况下,DHCP 服务器 会维护一个供分配的地址池,每次从地址池中取出地址分配给请求的客户机。分配给客户机的地址只在一段时间内有效,这段时间称为租用期(lease duration)。客户机只能在租用期内使用分配的地址。客户机在租用期过半时开始尝试续订租约。
DHCP 协议消息
- 操作(OP): 8 位。标识消息是请求(1) 或应答(2)。
- 硬件类型(HTYPE): 8 位。当前网络数据链路层的协议类型, 实际指定了硬件地址类型。如,以太网的 HTYPE 是
1
。 - 硬件地址长度(HLEN): 8 位。硬件地址的长度(单位: 八位字节(Octets))。以太网的 HLEN 是
6
。 - 跳数(HOPS): 8 位。保存消息传输过程中的中继次数。消息发送方将该值设置为
0
,并在每次中继时递增。 - 事务 ID(XID):32 位。客户机选择的一个随机数,以标识消息。服务器在响应时,将该字段复制到响应消息中,以保证响应和请求的匹配。
- 秒数(SECS):16 位。第一次尝试申请或重新申请地址经过的秒数。
繁忙的 DHCP 服务器可能会在多个客户端请求未完成时使用此功能来优先处理响应。
(This may be used by a busy DHCP server to prioritize replies when multiple client requests are outstanding.) - 标志(FLAGS):16 位。目前只有第一位用作广播标志(Broadcast Flag)。如果设置了广播标志,则表示该客户机只能接收广播消息(可能还没有 IP 地址)。其他位保留,设为 0。
- 客户机 IP 地址(CIADDR): 32 位。请求者的 IP 地址,如果已知的话。否则,为 0。
- “你的” IP 地址(YIADDR): 32 位。DHCP 服务器 提供给主机的地址。
- (下一)服务器 IP 地址(SIADDR): 32 位。客户机应该在引导过程的下一步中使用服务器的地址。
- 网关(中继) IP 地址(GIADDR):32 位。由 DHCP 中继填写,它在转发 DHCP 消息时将自己的地址填入 GIADDR。
- 客户机硬件地址(CHADDR): 128 位。保存客户机的硬件地址。
- 服务器名(SNAME): 64 位。可选。服务器在发送 DHCPOFFER 或 DHCPACK 消息时,可以将自己的名字填入 SNAME 中。
- 引导文件名(FILE): 128 位。可选。客户端可以选择在 DHCPDISCOVER 消息中请求特定类型的引导文件。
- 选项(VEND): 可变。DHCP 选项格式如下图。DHCP 选项包括 DHCPDISCOVER(1),DHCPOFFER(2) 等。具体内容可查看 Summary Of DHCP Options / BOOTP Vendor Information Fields。