元素码农
基础
UML建模
数据结构
算法
设计模式
网络
TCP/IP协议
HTTPS安全机制
WebSocket实时通信
数据库
sqlite
postgresql
clickhouse
后端
rust
go
java
php
mysql
redis
mongodb
etcd
nats
zincsearch
前端
浏览器
javascript
typescript
vue3
react
游戏
unity
unreal
C++
C#
Lua
App
android
ios
flutter
react-native
安全
Web安全
测试
软件测试
自动化测试 - Playwright
人工智能
Python
langChain
langGraph
运维
linux
docker
工具
git
svn
🌞
🌙
目录
▶
网络层
▶
IP协议
IP数据报格式
子网划分原理
CIDR无类寻址
IP分片与重组
IP选项字段
▶
ICMP协议
差错报文类型
Ping实现原理
Traceroute原理
▶
ARP协议
地址解析原理
ARP缓存表
代理ARP
▶
路由协议
RIP协议详解
OSPF协议原理
BGP协议机制
▶
IPv6协议
IPv6地址结构
IPv6报文格式
IPv6扩展头
IPv6过渡技术
▶
移动IP
移动IP原理
代理发现机制
注册与路由优化
▶
网络QoS
QoS服务模型
IntServ架构
DiffServ架构
MPLS技术
▶
NAT技术
NAT原理与类型
NAT穿透技术
NAT64与DNS64
▶
组播路由
组播基础
IGMP协议
PIM协议族
▶
网络安全
IPSec协议族
VPN技术详解
DDoS防护
▶
传输层
▶
TCP协议
三次握手机制
滑动窗口原理
拥塞控制算法
四次挥手过程
超时重传机制
TCP状态转换
快速重传机制
快速恢复算法
选择性确认SACK
时间戳选项
▶
UDP协议
数据报结构解析
实时传输优化
UDP校验和计算
UDP广播与多播
UDP性能调优
UDP可靠传输
▶
SCTP协议
SCTP协议概述
多宿主支持
多流传输
关联建立过程
心跳机制
▶
传输层安全
TLS协议详解
DTLS协议
密钥交换机制
证书验证
▶
应用层
▶
HTTP协议
请求响应模型
持久连接机制
HTTP消息格式
状态码详解
Cookie机制
HTTP缓存机制
HTTP认证机制
HTTPS详解
TLS/SSL协议
HTTP/1.0详解
HTTP/1.1详解
HTTP/2详解
HTTP/3详解
▶
DNS系统
域名解析过程
记录类型详解
递归与迭代查询
DNS缓存机制
▶
FTP协议
FTP工作原理
主动与被动模式
FTP命令详解
▶
SMTP协议
邮件传输流程
SMTP会话过程
邮件格式规范
▶
DHCP协议
DHCP工作原理
地址分配过程
DHCP中继代理
▶
SNMP协议
SNMP架构
MIB数据库
SNMP操作
SNMPv3安全机制
▶
WebSocket协议
WebSocket原理
握手升级机制
数据帧格式
心跳与连接维护
▶
QUIC协议
QUIC协议特性
0-RTT建连
多路复用
丢包恢复
▶
gRPC协议
gRPC基础
服务定义
通信模式
负载均衡
发布时间:
2025-03-24 23:50
↑
☰
# IP分片与重组 ## 基础概念 IP分片(IP Fragmentation)是网络层的一个重要机制,它允许IP数据报在传输过程中被分割成更小的片段,以适应不同网络链路的最大传输单元(MTU)限制。当数据报到达目的地时,这些片段会被重新组装成完整的数据报。 ### 为什么需要分片 - 不同类型的网络有不同的MTU - 较大的IP数据报需要在较小MTU的网络中传输 - 确保数据传输的可靠性和效率 ## 分片过程 ### 分片机制 1. **分片标识** - 每个IP数据报都有一个唯一的标识字段 - 所有分片都继承原始数据报的标识值 - 用于区分不同数据报的分片 2. **分片标志** - MF(More Fragments):1表示后面还有分片,0表示是最后一个分片 - DF(Don't Fragment):1表示禁止分片 3. **片偏移** - 表示该分片在原始数据报中的位置 - 以8字节为单位 - 帮助接收端正确重组数据报 ### 分片示例 假设一个4000字节的IP数据报需要经过MTU为1500字节的网络: ``` 原始数据报(4000字节) 标识:1234 DF=0, MF=0 偏移:0 分片1(1480字节数据) 标识:1234 DF=0, MF=1 偏移:0 分片2(1480字节数据) 标识:1234 DF=0, MF=1 偏移:185 分片3(1040字节数据) 标识:1234 DF=0, MF=0 偏移:370 ``` ## 重组过程 ### 重组机制 1. **分片收集** - 目的主机收集具有相同标识的所有分片 - 检查MF标志和片偏移确定分片顺序 - 等待所有分片到达 2. **重组规则** - 按照片偏移顺序重组 - 检查是否有缺失的分片 - 验证重组后的数据报完整性 3. **超时处理** - 设置重组定时器 - 如果超时仍未收到所有分片,则丢弃已收到的分片 ## 实际应用 ### Path MTU Discovery 为避免分片,现代网络通常使用Path MTU Discovery机制: 1. 发送端将DF位置1 2. 如果数据报大小超过路径MTU,路由器返回ICMP错误消息 3. 发送端根据ICMP消息调整数据报大小 ### 分片的影响 1. **性能影响** - 增加处理开销 - 可能导致延迟增加 - 丢包率可能升高 2. **安全考虑** - 分片可能被用于绕过安全设备 - 需要特别的安全策略处理分片数据报 ### 最佳实践 1. **避免分片** - 应用层合理设置数据大小 - 使用Path MTU Discovery - TCP MSS协商 2. **监控和调优** - 监控分片和重组失败率 - 适当调整重组缓冲区大小 - 优化网络MTU配置 ## 调试技巧 ### 常见问题 1. **分片丢失** - 使用tcpdump捕获分片 - 分析分片序列号和偏移 - 检查网络设备是否正确处理分片 2. **重组超时** - 查看系统日志 - 调整重组超时时间 - 检查网络延迟 ### 调试命令 ```bash # 查看分片情况 ping -s 2000 example.com # 禁止分片 ping -D example.com # 捕获分片数据包 tcpdump 'ip[6] & 0x20 != 0 or ip[6:2] & 0x1fff != 0' ``` ## 总结 IP分片与重组是网络层的重要机制,它使得IP数据报能够适应不同网络的MTU限制。虽然现代网络倾向于避免分片,但理解这一机制对于网络故障排查和优化仍然很重要。在实际应用中,应当权衡使用分片的利弊,采取适当的策略来优化网络性能。