DHCP 握手原理

DHCP 握手原理

一、DHCP 概述

动态主机配置协议(Dynamic Host Configuration Protocol,DHCP) 用于自动分配网络配置参数(如 IP 地址、子网掩码、网关、DNS 等),简化手动配置流程。其核心是 DORA 四步握手 (Discover → Offer → Request → Acknowledge),基于 UDP 协议(客户端端口 68,服务器端口 67)。

二、DHCP 四步握手流程

1. 阶段 1:Discover(客户端广播请求)

  • 触发场景:客户端初始化(如开机、重启、未获取到 IP)。
  • 消息DHCPDISCOVER
  • 源地址0.0.0.0(客户端无 IP)
  • 目标地址255.255.255.255(广播)
  • 内容
    • 客户端 MAC 地址
    • 请求的参数(如 IP 地址、租期)

流程图

复制代码
Client:  DHCPDISCOVER ────────────────▶ 广播网络

2. 阶段 2:Offer(服务器响应)

  • 触发场景 :DHCP 服务器收到 DHCPDISCOVER
  • 消息DHCPOFFER
  • 源地址:DHCP 服务器 IP
  • 目标地址255.255.255.255(广播,客户端仍无 IP)
  • 内容
    • 提供的 IP 地址、子网掩码
    • 租期、服务器标识(IP)

流程图

复制代码
Server:  ◀────────── DHCPOFFER ─────────── 广播网络

3. 阶段 3:Request(客户端确认选择)

  • 触发场景 :客户端可能收到多个 DHCPOFFER,选择其中一个。
  • 消息DHCPREQUEST
  • 源地址0.0.0.0(未正式分配 IP)
  • 目标地址255.255.255.255(广播)
  • 内容
    • 选中的服务器 IP
    • 请求的 IP 地址

流程图

复制代码
Client:  DHCPREQUEST ────────────────▶ 广播网络

4. 阶段 4:Acknowledge(服务器确认分配)

  • 触发场景 :服务器收到 DHCPREQUEST,确认分配。
  • 消息DHCPACK
  • 源地址:DHCP 服务器 IP
  • 目标地址:客户端 IP(此时客户端已临时使用分配的 IP)
  • 内容
    • 正式分配的 IP 地址、租期
    • 完整网络配置参数(网关、DNS 等)

流程图

复制代码
Server:  ◀────────── DHCPACK ──────────── 客户端

三、关键机制与细节

1. 消息类型与端口

阶段 消息 UDP 源端口 UDP 目标端口 传输方式
1-3 步 DISCOVER/REQUEST 68 67 广播
2-4 步 OFFER/ACK 67 68 单播/广播

2. 状态机(客户端)

3. 续租机制

  • T1 时间 (租期的 50%):客户端发送 DHCPREQUEST 续租。
  • T2 时间 (租期的 87.5%):若 T1 未响应,广播 DHCPREQUEST 续租。
  • 租期过期:客户端释放 IP,回到 INIT 状态。

4. 异常处理

  • 无服务器响应:客户端定期重发 DISCOVER(指数退避策略)。
  • IP 冲突 :客户端检测到 IP 冲突时,发送 DHCPDECLINE 拒绝分配。

四、示意图

复制代码
Client       DHCP Server
  │                 │
  │  DHCPDISCOVER  │
  ├───────────────▶│ (广播)
  │                 │
  │◀───────────────│  DHCPOFFER (单播/广播)
  │  DHCPREQUEST   │
  ├───────────────▶│ (广播)
  │                 │
  │◀───────────────│  DHCPACK (单播)
  │  IP 已分配     │

五、常见问题

  1. 为什么前两步使用广播?

    客户端初始无 IP,无法单播;服务器需通过广播响应所有客户端。

  2. DHCP 与 BOOTP 的区别?

    DHCP 是 BOOTP 的扩展,支持动态租期、续租、更多配置参数。

  3. 能否分配固定 IP?

    可以,通过 DHCP 服务器的 静态绑定(根据客户端 MAC 地址分配固定 IP)。

DHCP 通过 DORA 四步握手 实现 IP 地址的动态分配,结合广播与单播机制,确保网络配置的自动化与高效性。

相关推荐
百***480714 小时前
【Golang】slice切片
开发语言·算法·golang
q***925114 小时前
Windows上安装Go并配置环境变量(图文步骤)
开发语言·windows·golang
仟濹14 小时前
【Java 基础】面向对象 - 继承
java·开发语言
郝学胜-神的一滴14 小时前
Linux命名管道:创建与原理详解
linux·运维·服务器·开发语言·c++·程序人生·个人开发
2501_9416233215 小时前
C++高性能网络服务器与epoll实战分享:大规模并发连接处理与事件驱动优化经验
开发语言·php
晚风(●•σ )15 小时前
C++语言程序设计——11 C语言风格输入/输出函数
c语言·开发语言·c++
阿珊和她的猫15 小时前
HTTP 状态码 301 和 302 的区别与使用场景
网络·网络协议·http
likuolei15 小时前
XML 元素 vs. 属性
xml·java·开发语言
X***489615 小时前
C源代码生成器
c语言·开发语言
梁正雄15 小时前
2、Python流程控制
开发语言·python