元素码农
基础
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-28 10:02
↑
☰
# TCP选择性确认机制 ## 概述 TCP选择性确认(Selective Acknowledgment,SACK)是TCP协议的一个重要扩展,它允许接收方告知发送方哪些数据包已经正确接收,哪些数据包还未收到,从而提高网络传输效率,特别是在出现多个数据包丢失的情况下。 ## 工作原理 ### SACK选项格式 1. SACK选项字段 - 选项类型:Kind = 5 - 选项长度:可变 - SACK块:包含左边界和右边界 2. SACK块内容 - Left Edge:已接收数据的起始序号 - Right Edge:已接收数据的结束序号 ### 工作流程 ```mermaid sequenceDiagram participant S as 发送方 participant R as 接收方 Note over S,R: 正常传输 S->>R: seq=1000, len=500 R->>S: ack=1500 S->>R: seq=1500, len=500 (丢失) S->>R: seq=2000, len=500 Note over R: 检测到数据空洞 R->>S: ack=1500, SACK=2000-2500 S->>R: seq=2500, len=500 R->>S: ack=1500, SACK=2000-3000 Note over S: 根据SACK信息 Note over S: 重传丢失数据 S->>R: seq=1500, len=500 (重传) R->>S: ack=3000 ``` ## 实现机制 ### 1. 发送方处理 1. 维护重传队列 - 记录已发送但未确认的数据 - 标记SACK确认的数据段 2. 重传策略 - 优先重传未被SACK确认的数据 - 使用选择性重传而非累积重传 ### 2. 接收方处理 1. 乱序数据缓存 - 维护接收窗口内的数据 - 记录已接收的不连续数据块 2. SACK生成 - 在ACK中携带SACK选项 - 最多包含4个SACK块 ## 性能优化 ### 1. 与快速重传配合 1. 精确重传 - 准确定位丢失的数据包 - 避免不必要的重传 2. 提高恢复效率 - 减少重传延迟 - 优化带宽利用 ### 2. 缓冲区管理 1. 发送方优化 - 合理分配重传缓冲区 - 及时清理已确认数据 2. 接收方优化 - 高效管理乱序数据 - 及时释放缓存空间 ## 应用场景 ### 1. 高丢包环境 1. 无线网络 - 信号干扰导致丢包 - 多径传播引起乱序 2. 拥塞网络 - 缓冲区溢出 - 路由器丢包 ### 2. 高延迟网络 1. 卫星通信 - 长距离传输 - 大带宽延迟积 2. 跨洲际网络 - 多跳传输 - 路径变化 ## 最佳实践 ### 1. 配置建议 1. 启用SACK选项 - 协商SACK能力 - 设置合适的缓冲区 2. 调优参数 - 最大SACK块数量 - 重传超时设置 ### 2. 监控指标 1. 性能监控 - SACK块使用率 - 重传效率分析 2. 故障诊断 - 丢包模式识别 - 网络状况评估 ## 注意事项 ### 1. 兼容性考虑 1. 操作系统支持 - 确认系统是否支持SACK - 检查是否正确启用 2. 中间设备兼容 - 防火墙配置 - 负载均衡器设置 ### 2. 安全性考虑 1. 资源消耗 - 控制缓冲区大小 - 防止内存耗尽 2. 攻击防范 - 验证SACK选项 - 限制重传次数