3.2 无连接运输:UDP 协议|《计算机网络:自顶向下方法》精读

一、UDP 核心定位:极简的 "尽力而为" 服务

UDP(User Datagram Protocol,用户数据报协议)是因特网最简单的运输层协议,它在 IP 层的基础上,只做了两件事:

  1. 增加了端口号,实现进程到进程的多路复用 / 分解
  2. 增加了校验和,提供最基本的差错检测

它不建立连接、不保证可靠、不做流量控制、不做拥塞控制,完全是 "轻装上阵",因此在实时场景中表现极佳。

UDP 的核心特点

  • 无连接:发送前不需要三次握手,直接封装数据发送,延迟极低
  • 不可靠传输:不保证数据一定到达,不保证顺序,丢包不会重传
  • 面向消息:保留应用层的消息边界,一次发送对应一次接收
  • 无状态:不维护任何连接信息,开销极小
  • 无拥塞控制:发送速率不受网络状态限制,适合对延迟敏感的场景

典型应用场景

  • DNS 查询:需要快速解析,超时可重试
  • 音视频通话 / 直播:短暂模糊比卡顿更可接受
  • 在线游戏:延迟敏感,丢包可通过插值补全
  • 实时物联网数据:高频小数据,允许少量丢失

3.3.1 UDP 报文段结构

UDP 报文段非常简洁,只有 8 字节的首部 + 应用层数据,没有任何冗余字段,这也是它高效的关键。

UDP 报文段格式(二进制)

字段 长度(bit) 含义
源端口号 16 发送方进程的端口号(可选,无连接时可填 0)
目的端口号 16 接收方进程的端口号(必须,用于多路分解)
长度 16 UDP 报文段的总长度(首部 8 字节 + 数据部分),最小值为 8
校验和 16 检测报文在传输过程中是否出错(可选,但强烈建议使用)
数据部分 可变 应用层交付的数据,长度受限于 UDP 长度字段和 IP 分片

关键细节

  1. 长度字段
    • 单位为字节,最小值是 8(只有首部,无数据)
    • 最大值为 65535,但受 IP 数据包总长度限制(通常不超过 1472 字节,避免 IP 分片)
  2. 源端口号
    • 客户端发送时通常填写临时端口,服务器回复时会用此端口作为目的端口
    • 若不需要回复(如单向广播),可设为 0
  3. 数据边界
    • UDP 是面向消息的,应用层写多少数据,UDP 就封装成一个报文段发送
    • 接收方必须完整接收一个报文段,不能只读取部分字节(和 TCP 面向字节流的特性形成鲜明对比)

3.3.2 UDP 校验和算法

校验和是 UDP 唯一的差错检测机制,用于发现报文在传输过程中是否发生了比特翻转( corruption),它不纠错,只检测,发现错误后直接丢弃报文。

校验和计算范围

UDP 校验和不仅覆盖 UDP 报文段本身,还需要加上一个 12 字节的伪首部(Pseudo Header),这是为了:

  1. 检测 IP 地址是否错误(避免报文被投递到错误主机)
  2. 检测运输层协议是否错误(避免被 TCP 误处理)

伪首部格式(仅用于计算校验和,不随报文发送)

字段 长度(bit) 含义
源 IP 地址 32 发送方 IP
目的 IP 地址 32 接收方 IP
保留字段 8 固定为 0
协议号 8 UDP 协议号为 17
UDP 长度 16 同 UDP 首部中的长度字段

校验和计算步骤

  1. 将伪首部、UDP 首部、数据部分拼接在一起(若数据部分长度为奇数,需在末尾补一个 0 字节,凑成 16 位对齐)
  2. 按 16 位为一个单位,将所有 16 位字进行二进制反码求和
  3. 对求和结果取反,得到校验和,填入 UDP 首部的校验和字段
  4. 接收方收到后,重复步骤 1-2,若结果为全 1(0xFFFF),则校验通过;否则丢弃报文

关键特性

  • 可选性:UDP 校验和是可选的,设为 0 表示不计算校验和(但在 IPv6 中强制要求开启)
  • 差错检测:只能检测出比特错误,无法检测丢包、乱序、重复
  • 伪首部作用:将 IP 层信息纳入校验,避免报文被错误路由或错误解析

✅ 本节核心总结

  1. UDP 是极简协议:在 IP 基础上只增加了端口和校验和,无连接、不可靠、轻量高效
  2. 报文结构极简:8 字节首部,无冗余,面向消息,保留数据边界
  3. 校验和机制:使用伪首部 + 反码求和,提供基础差错检测,不纠错
  4. 适用场景:实时性优先、允许少量丢包的业务,是音视频、游戏、DNS 的首选协议

📌 下一节预告

3.3 可靠数据传输原理:从最简单的停等协议开始,逐步进化到 GBN、SR,最终理解 TCP 可靠传输的底层逻辑,这是本章最硬核的部分。

相关推荐
TechWayfarer3 小时前
IP归属地API 技术解析与应用实践
网络·网络协议·tcp/ip
河阿里4 小时前
JWT 与 Cookie/Session 的对比分析
网络协议
路由侠内网穿透.6 小时前
本地部署开源客服系统 FreeScout 并实现外部访问( Windows 版本)
运维·服务器·网络·windows·网络协议
你觉得脆皮鸡好吃吗6 小时前
Check Anti-CSRF Token (AI)
前端·网络·网络协议·安全·csrf·网络安全学习
小红的布丁11 小时前
计算机网络入门:OSI 五层模型、各层协议和数据单位
计算机网络
小红的布丁11 小时前
IP、子网、私有地址、ARP 与 Ping 通信全过程
网络·网络协议·tcp/ip
以太浮标13 小时前
华为eNSP综合实验之- 交换机组播VLAN(Multicast-VLAN)详细解析
运维·网络·网络协议·网络安全·华为·自动化·信息与通信
mounter62513 小时前
【深度解析】Device Memory TCP:开启高性能网络传输的“零拷贝”新时代
linux·服务器·网络·网络协议·tcp/ip·kernel·devmem
KevinCyao14 小时前
彩信http接口如何接入?采用POST方式提交多媒体附件的彩信示例
网络·网络协议·http
551只玄猫14 小时前
【计算机网络 实验报告1】Wireshark软件的使用
计算机网络·测试工具·wireshark·课程设计·实验报告