【TCP:可靠数据传输,快速重传,流量控制,TCP流量控制】

可靠数据传输

TCP:可靠数据传输

  • TCP在IP不可靠服务的基础上建立了rdt
    • 管道化的报文段
      • GBN or SR
    • 累计确认(像GBN)
    • 单个重传定时器(像GBN)
    • 是否可以接受乱序的,可以缓存,也可以丢弃
  • 通过以下事件触发重传
    • 超时(只重发那个最早的未确认段:SR)
    • 重复的确认
      • 例子:收到了ACK50,之后又收到3个ACK50
  • 首先考虑简化的TCP发送方:
    • 考虑重复的确认
    • 忽略流量控制和拥塞控制
      在这里插入图片描述
      NextSeqNum = NextSeqNum + length(data):
      发送窗口前沿向前移动。
      SendBase = y
      /* SendBase–1: last cumulatively ACKed byte */
      if (there are currently not-yet-acked segments) start timer else stop timer:
      发送窗口后沿向前移动,没有已发送未确认的字节,关掉定时器。

TCP发送方事件

从应用层接收数据:

  • 用nextseq创建报文段
  • 序号nextseq为报文段首字节的字节流编号
  • 如果还没有运行,启动定时器
    • 定时器与最早未确认的报文段关联
    • 过期间隔:TimeOutInterval
      超时:
  • 重传后沿最老的报文段
  • 重新启动定时器
    收到确认:
  • 如果是对尚未确认的报文段确认
    • 更新已被确认的报文序号
    • 如果当前还有未被确认的报文段,重新启动定时器
      在这里插入图片描述
      解释:这里发送方传送的序号从92开始的,8个字节,接收方收到给一个ACK100的确认,但是这个确认丢失,发送方又传了100开始,20个字节。这个时候就要重发92,8。
      在这里插入图片描述
      这里有几种情况:
      ①隐忍不发,等多个报文在一起时候再一起发。
      ②延时等待,下一个报文在延时时间发了的话,就一起发送。没发的话,就只发送一个ACK。
      ③在发送重复的ACK,指明下一个期待的字节序号。
      ④若报文中间有gap间隔,完全补齐的话,就发送所有的ACK,部分补齐的话,就发送补齐部分。

快速重传

  • 超时周期往往太长:
    • 在重传丢失报文段之前的延时太长
  • 通过重复的ACK来检测报文段丢失
    • 发送方通常连续发送大量报文段
    • 如果报文段丢失,通常会引起多个重复的ACK
  • 如果发送方收到同一数据的3个冗余ACK,重传最小序号的段:
    • 快速重传:在定时器过时之前重发报文段
    • 在这里插入图片描述
      在这里插入图片描述

流量控制

TCP流量控制

流量控制:接收方控制发送方,不让发送方发送的太多,太快以致于让接收方的缓冲区溢出。
在这里插入图片描述

  • 接收方在其向发送方的TCP段头部的rwnd字段“通告”其空闲buffer大小。
  • 保证接收方不会被淹没。
    在这里插入图片描述
    在这里插入图片描述
  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值