以太网 TCP协议交互过程中出现丢包时的解决机制,超时重传、快速重传、SACK与DSACK

2.7.3 以太网 TCP协议(TCP交互过程中出现丢包时的解决机制-列举部分)

参考:CSDN_TCP的重传机制_博主.Pr Young,对描述进行了整理与结合个人的理解进行编写。

一、超时重传机制

  • 在发送数据时,设定一个定时器,当超过指定的时间后,没有收到对方的 ACK 确认应答报文,就会重发该数据。

    当数据包丢失确认应答ACK丢失之后,将发生超时重传。

二、快速重传机制

  • 当多次收到同样的ACK置位TCP报文,将根据ACK置位报文中的ack序号信息进行重传相应的数据。
  • 发送端收到了三个 Ack = 2 的确认,知道了 Seq2 还没有收到,就会重传Seq2
  • 最后,收到了 Seq2,此时因为 Seq3,Seq4,Seq5 都收到了,于是 Ack 回 6

三、SACK(选择性确认)机制

  • SACK( Selective Acknowledgment )选择性确认
  • 与快速重传机制有一定的相似性,SACK中可连续接收发来的报文,SACK用于表示已经接收的报文ACK表示待接收的报文
  • ACK到SACK之间就是需要进行重发的数据范围。

四、Duplicate SACK

  • 工作方式与SACK一样,主要是针对ack丢失的情况和网络延时的情况,SACK有不同的表示方式。

  • Duplicate SACK又称 D-SACK,其主要使用了 SACK 来告诉「发送方」有哪些数据被重复接收了。

解释图中表示内容:

  • 接收方发给发送方的两个 ACK 确认应答都丢失了。第一个包的定时器到了并没有收到接收方回复的ACK确认,将重传第一个数据包(3000 ~ 3499)。

  • 好巧不巧,这次重传的数据回复的ACK终于正常被发送方收到,但ACK内容是:ACK=4000、SACK=3000~3499,意为成功接收了前面的报文,期待下一个数据包编号是4000开始,但收到了重复的数据:3000~3500。

  • 发送方根据回复的ACK、SACK知道发送的数据没有丢,只是接收方的 ACK 确认报文丢了。

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hades_Ling

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值