12 TCP:传输控制协议(初步)

12.1 引言

​ 以太网上的很多协议自身不包含可靠传输机制,他们可能会使用一种类似于校验和或者CRC这样的数学函数来检测接收到的数据是否包含差错,但是他们不会去尝试纠正差错。尤其对于IP协议和UDP协议,根本没有实现差错纠正功能。虽然一些基于IP协议或者UDP协议的上层协议会提供一定次数的重传机制,但是如果不成功依然会放弃重传。

​ 通讯媒介可能会丢失或者改变被传递的信息。目前有两种主要的手段来尽量避免信息在传输过程中的出错:

  • 差错校验码: (基本上是添加一些荣誉的比特,使得即使某些比特被修改,真实的信息也能被恢复出来),使用差错校正码来纠正通讯问题是除了差错的一种非常重要的方法。

  • ARQ: (Automatic Repeat Request), 这种方法简称自动重复请求,它构成了很多协议的基础,其中便包括TCP协议。

12.1.1 ARQ和重传

​ 在讨论IP数据包时经常遇到的几个问题:分组重新排序、分组复制、分组丢失。一个直接处理分组丢失的方法是重新发送分组知道它被正确的接收。这需要一种方法来判断:

1) 接收方是否受到分组 ?

2) 接收方接收到的分组是否和发送方发的数据完全一样 ?

​ 接收到通过给发送方发送信号来确定自己已经收到一个分组,这种方法称为 确认(acknowledagment)或者ACK

最基本的形式应该是:

i. 发送方发送一个分组,然后等待一个ACK。

ii. 当接收到收到这个分组后,应该发送对应的ACK;

iii. 发送方接收到这个ACK, 他再发送另外一个分组报文。之后一直重复这样的流程

但是这里有引入另外的问题:

(1) 发送方对一个分组的ACK应该等待多长时间 ?

(2) 如果ACK报文丢失了怎么办 ?

(3) 如果分组被接收到,但是里面包含错误信息怎么办 ?

答案是:

(1) 第一个问题比较深奥。决定等待多长时间与发送发期待(expect)为一个ack等待的时间有关。后续讨论

(2) 第二个问题比较容易: 如果一个ACK丢失了,发送方不能轻易的将这种情况与原分组丢失的情况区分开,因此它简单的再次发送原分组即可。 这样的话,接收方可能会接收到多个重复的副本,因此接受方必须处理这种情况。

(3) 第三个问题:我们使用校验和的形式来检测分组中是否包含差错,如果包含差错,则不回复相应的ACK报文,这样发送方会重新发送该分组。

当目前为止,即使最简单的应用场景也会遇到一个问题:接收方可能会接收到多个重复的副本

解决这个问题需要使用序列号(sequence number)来处理。接收方通过报文分组中的序列号来判断当前的报文是否已经接收到。如果是,则将该分组丢弃。

​ 到目前为止介绍的协议虽然是可靠的,但是效率低,吞吐量小。因为每次发送一个分组都需要**“停止和等待”**。对于不会损坏和丢失太多分组的网络,低吞吐量的原因在于网络经常处于闲暇的状态-----如果我们允许多个分组同时进入网络,就可以使它“更繁忙”,从而提高网络吞吐量。

​ 很明显,允许多个分组同时进入网络中,会是事情变得更加复杂:

  • 发送方

(1)我们不仅要决定什么时间将分组注入网络,还要决定注入多少个分组;

(2)并且必须指出等待ACK时,怎样维持计时器;

(3)同时还需要保存每一个尚未确认分组的副本以防重传。

  • 接收方

(1)接收方需要更为复杂的ACK确认机制:可以区分哪些分组已经接收到,哪些分组尚未接收;

(2)此外接收方还需要更复杂的缓存机制:允许维护“次序杂乱”的分组

  • 其他

(1)接收方和发送方速率不匹配该怎么处理 ?,例如发送的快,接收速率慢。

12.1.2 分组窗口和滑动窗口

​ 为了解决所有这些问题,我们假设每一个分组有一个序列号开始。我们定义一个分组窗口(window)作为已被发送方发送但是尚未完成确认的分组集合,我们把这个窗口中的分组数量称为窗口大小(window size)。

​ 上图显示了当前三个分组的窗口,整个窗口大小为3。

1) 3号分组已经被发送并且收到对方的ACK确认报文,因此发送方保存的副本可以被释放。

2) 7号分组已经准备好,但尚未被发送。因为它尚未进入“窗口”中。

​ 现在我们想象数据从发送方流向接收方,ACK从相反的方向流动,发送方可能下一步接收到分组4的ACK报文。当这种情况发生时,窗口向右边滑动一个分组,分组4的副本可以被释放,而分组7可以被发送。窗口的这种滑动给这种类型的协议增加了一个名字:“滑动窗口”(sliding window)协议

​ 采用“滑动窗口”的方法可以对付目前为止表述过的许多问题。一般说来,这个窗口结构在发送方和接收方都会存在:

  • 发送方

    记录哪些分组可以被释放、哪些分组已经发送正等待确认、哪些分组不可以被发送。

  • 接收方

    记录哪些分组已经被接收确认、哪些分组是下一步期望的(包括已经分配多少内存来保存他们)、哪些分组即使被接受也会被丢弃。

尽管窗口结构便于记录在发送方和接收方之间流动的数据,但是关于窗口应该有多大,或者接收方处理不过来发送的数据时会发生什么,它都没有提供相应的方法

12.1.3 变量窗口:流量控制和拥塞控制


​ 如上图所示,三者的速率为q>m>n时,网络的瓶颈在于接收方。当接收方相对于发送方处理出具太慢时会出现问题。我们常用的方法是:强迫发送方慢下来,这被称为流量控制(flow control)。常见的流量控制有两种方式:

  • 基于速率(speed-based)

    他是给发送方指定某个速率,同时确保发送的数据永远不会超过这个速率。这种类型的流量控制比较适合应用程序,可用于组播或者广播的发现。

  • 基于窗口(window-based)

    它是基于滑动窗口的方式,在这种情况下,窗口大小是随着时间大小可变的。接收方用来通知发送方窗口大小的报文成为窗口通告(window advertisement)或者窗口更新(window update)。 逻辑上将虽然窗口更新和ACK报文是分离的,但是实际上窗口更新和ACK经常由同一个分组携带,意味着发送方往往会在它的窗口滑动到右边时同时调整它的窗口的大小


​ 如上图所示,三者的速率为m>n>q时,网络的瓶颈在于中间的网络设备。此时如果发送方和接收方采用超过中间网络设备能够处理的最大速率同样会造成数据的丢失。这种情况称为拥塞控制(congestion control)。拥塞控制主要指的是发送方的速率大于中间某一路由器设备的速率时,我们需要采取措施,不至于压垮其与接收方之间的网络。

12.1.4 变量窗口:设置重传超时

​ 这个值不确定,是一个基于大量的数据统计结果。

整理自《TCPIP详解 卷1》

TCP超时重传、序列号、滑动窗口简介的更多相关文章

  1. TCP超时重传、滑动窗口、拥塞控制、快重传和快恢复

    TCP超时重传 原理是在发送某一个数据以后就开启一个计时器,在一定时间内如果没有得到发送的数据报的ACK报文,那么就重新发送数据,直到发送成功为止. 影响超时重传机制协议效率的一个关键参数是重传超时时 ...

  2. 【编程之美】超时重传,滑动窗口,可靠性传输原理C语言实现

    版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://www.cnblogs.com/lihuidashen/p/128003 ...

  3. tcp的精髓:滑动窗口

    TCP协议作为一个可靠的面向流的传输协议,其可靠性和流量控制由滑动窗口协议保证,而拥塞控制则由控制窗口结合一系列的控制算法实现.一.滑动窗口协议 关于这部分自己不晓得怎么叙述才好,因为理解的部分更多, ...

  4. TCP面试题之滑动窗口原理

    TCP 滑动窗口 作用: 1. 提供TCP可靠性:对发送的数据进行确认 2. 流量控制:窗口大小随链路变化 一.TCP窗口机制 TCP中窗口大小是指tcp协议一次传输多少个数据.因为TCP是一个面向连 ...

  5. 【原创】TCP超时重传机制探索

    TCP超时重传机制探索 作者:tll (360电商技术) 1)通信模型 TCP(Transmission Control Protocol)是一种可靠传输协议.在传输过程中当发送方(sender)向接 ...

  6. TCP超时重传时间的选择

    一---导读 TCP超时重传时间的选择是计算机网络中较复杂的问题之一,但幸好前辈们都把路铺好了,我们只需要学习并且遵循这些规则,有能力的话去进一步改正. 二---必知的一些专业术语 A--RTT( r ...

  7. 【图解】你还在为 TCP 重传、滑动窗口、流量控制、拥塞控制发愁吗?看完图解就不愁了

    每日一句英语学习,每天进步一点点: 前言 前一篇「硬不硬你说了算!近 40 张图解被问千百遍的 TCP 三次握手和四次挥手面试题」得到了很多读者的认可,在此特别感谢你们的认可,大家都暖暖的. 来了,今 ...

  8. 面试之路(29)-TCP流量控制和拥塞控制-滑动窗口协议详解

    拥塞: 拥塞发生的主要原因在于网络能够提供的资源不足以满足用户的需求,这些资源包括缓存空间.链路带宽容量和中间节点的处理能力.由于互联网的设计机制导致其缺乏"接纳控制"能力,因此在 ...

  9. TCP状态转换图、滑动窗口、半连接状态、2MSL

    一.TCP状态转换图 下图对排除和定位网络或系统故障时大有帮助,也帮助我们更好的编写Linux程序,对嵌入式开发也有指导意义.    先回顾一下TCP建立连接的三次握手过程,以及关闭连接的四次握手过程 ...

随机推荐

  1. nfs配置项在/etc/exports中的说明

    rw 可读写的权限 ro 只读的权限no_root_squash 登入NFS主机,使用该共享目录时相当于该目录的拥有者,如果是root的话,那么对于这个共享的目录来说,他就具有root的权       ...

  2. laod

    https://iiio.io/download/20170120/ https://laod.cn/hosts/2017-google-hosts.html Copyright (c) 老D博客:h ...

  3. 又一开源项目爆火于GitHub,Android高级插件化强化实战

    一.插件化起源 插件化技术最初源于免安装运行 Apk的想法,这个免安装的 Apk 就可以理解为插件,而支持插件的 app 我们一般叫 宿主. 想必大家都知道,在 Android 系统中,应用是以 Ap ...

  4. 【Android面试揭秘】面试官说“回去等通知”,我到底会不会等来通知?

    前言 大部分情况下,面试结束后,面试官都会跟你说:我们会在1-2个工作日内通知你面试结果. 许多人认为:所谓「等通知」其实是面试官委婉地给你「发拒信」.但是,这不是「等通知」的全部真相. 这篇文章,我 ...

  5. 七夕特别篇|用Python绘画牛郎织女在鹊桥相见

    大家好,我是辰哥~ 今天就是七夕节,首先提前祝福有伴侣的小伙伴,七夕快乐,没有伴侣的小伙伴,今天就会找到伴侣,(给看到这句话的你好运加持,哈哈哈). 作为会Python的我们必须做点好玩且有意义的东西 ...

  6. Java8新特性(二)之函数式接口

    .subTitle { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); border- ...

  7. hg的常用配置

    hg的配置文件分为全局配置和每个Repo自己的配置,Ubuntu系统下全局配置文件是~/.hgrc,Win7系统下是C:\Users\chad\mercurial.ini,各repo的配置文件是$RE ...

  8. scrapy爬虫框架使用

    一.scrapy框架 1.什么是scrapy: 爬虫中封装好的一个明星框架.功能:高性能的持久化存储,异步的数据下载,高性能的数据解析,分布式. 2.使用方法: 安装: 下载tiwisted,此处位下 ...

  9. 007 GMII、SGMII和SerDes的区别和联系

    一.GMII和SGMII的区别和联系 GMII和SGMII区别,上一篇已经介绍了,这一篇重点介绍SGMII和SerDes区别. GMII和SGMII GMII 在MII接口基础上提升了数据位宽和Clo ...

  10. 11-SpringCloud Hystrix

    Hystrix简介 分布式系统面临的问题 复杂分布式体系结构中的应用程序有数十个依赖关系,每个依赖关系在某些时候将不可避免地失败. 服务雪崩 多个微服务之间调用的时候,假设微服务A调用微服务B和微服务 ...