`
san_yun
  • 浏览: 2663515 次
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

TCP滑动窗口

 
阅读更多

目前建立在TCP协议上的网络协议特别多,有telnet,ssh,有ftp,有http等等。这些协议又可以根据数据吞吐量来大致分成两大 类:(1)交互数据类型,例如telet,ssh,这种类型的协议在大多数情况下只是做小流量的数据交换,比如说按一下键盘,回显一些文字等等。(2)数 据成块类型,例如ftp,这种类型的协议要求TCP能尽量的运载数据,把数据的吞吐量做到最大,并尽可能的提高效率。针对这两种情况,TCP给出了两种不 同的策略来进行数据传输。

1.TCP的交互数据流

对于交互性要求比较高的应用,TCP给出两个策略来提高发送效率和减低网络负担:(1)捎带ACK。(2)Nagle算法(一次尽量多的发数据)。通常,在网络速度很快的情况下,比如用lo接口进行telnet通信,当按下字母键并要求回显的时候,客户端和服务器将经历 发送按键数据->服务器发送按键数据的ack -> 服务器端发送回显数据->客户端发送回显数据的ACK的过程,而其中的数据流量将是40bit + 41bit+41bit+40bit = 162bit,如果在广域网里面,这种小分组的TCP流量将会造成很大的网络负担。

1.1.捎带ACK的发送方式

这个策略是说,当主机收到远程主机的TCP数据报之后,通常不马上发送ACK数据报,而是等上一个短暂的时间,如果这段时间里面主机还有发送到远程 主机的TCP数据报,那么就把这个ACK数据报“捎带”着发送出去,把本来两个TCP数据报整合成一个发送。一般的,这个时间是200ms。可以明显地看 到这个策略可以把TCP数据报的利用率提高很多。

1.2.Nagle算法

上过bbs的人应该都会有感受,就是在网络慢的时候发贴,有时键入一串字符串以后,经过一段时间,客户端“发疯”一样突然回显出很多内容,就好像数据一下子传过来了一样,这就是Nagle算法的作用。
Nagle算法是说,当主机A给主机B发送了一个TCP数据报并进入等待主机B的ACK数据报的状态时,TCP的输出缓冲区里面只能有一个TCP数 据报,并且,这个数据报不断地收集后来的数据,整合成一个大的数据报,等到B主机的ACK包一到,就把这些数据“一股脑”的发送出去。虽然这样的描述有些 不准确,但还算形象和易于理解,我们同样可以体会到这个策略对于低减网络负担的好处。
在编写插口程序的时候,可以通过TCP_NODELAY来关闭这个算法。并且,使用这个算法看情况的,比如基于TCP的X窗口协议,如果处理鼠标事件时还是用这个算法,那么“延迟”可就非常大了。

2.TCP的成块数据流

对于FTP这样对于数据吞吐量有较高要求的要求,将总是希望每次尽量多的发送数据到对方主机,就算是有点“延迟”也无所谓。TCP也提供了一整套的策略来支持这样的需求。TCP协议中有16个bit表示“窗口”的大小,这是这些策略的核心。

2.1.传输数据时ACK的问题

在解释滑动窗口前,需要看看ACK的应答策略,一般来说,发送端发送一个TCP数据报,那么接收端就应该发送一个ACK数据报。但是事实上却不是这 样,发送端将会连续发送数据尽量填满接受方的缓冲区,而接受方对这些数据只要发送一个ACK报文来回应就可以了,这就是ACK的累积特性,这个特性大大减 少了发送端和接收端的负担。

2.2.滑动窗口

滑动窗口本质上是描述接受方的TCP数据报缓冲区大小的数据,发送方根据这个数据来计算自己最多能发送多长的数据。如果发送方收到接受方的窗口大小 为0的TCP数据报,那么发送方将停止发送数据,等到接受方发送窗口大小不为0的数据报的到来。书中的P211和P212很好的解释了这一点。
关于滑动窗口协议,书上还介绍了三个术语,分别是:
  1. 窗口合拢:当窗口从左边向右边靠近的时候,这种现象发生在数据被发送和确认的时候。
  2. 窗口张开:当窗口的右边沿向右边移动的时候,这种现象发生在接受端处理了数据以后。
  3. 窗口收缩:当窗口的右边沿向左边移动的时候,这种现象不常发生。
TCP就是用这个窗口,慢慢的从数据的左边移动到右边,把处于窗口范围内的数据发送出去(但不用发送所有,只是处于窗口内的数据可以发送。)。这就 是窗口的意义。图20-6解释了这一点。窗口的大小是可以通过socket来制定的,4096并不是最理想的窗口大小,而16384则可以使吞吐量大大的 增加。

2.3.数据拥塞

上面的策略用于局域网内传输还可以,但是用在广域网中就可能会出现问题,最大的问题就是当传输时出现了瓶颈(比如说一定要经过一个slip低速链 路)所产生的大量数据堵塞问题(拥塞),为了解决这个问题,TCP发送方需要确认连接双方的线路的数据最大吞吐量是多少。这,就是所谓的拥塞窗口。
拥塞窗口的原理很简单,TCP发送方首先发送一个数据报,然后等待对方的回应,得到回应后就把这个窗口的大小加倍,然后连续发送两个数据报,等到对 方回应以后,再把这个窗口加倍(先是2的指数倍,到一定程度后就变成现行增长,这就是所谓的慢启动),发送更多的数据报,直到出现超时错误,这样,发送端 就了解到了通信双方的线路承载能力,也就确定了拥塞窗口的大小,发送方就用这个拥塞窗口的大小发送数据。要观察这个现象是非常容易的,我们一般在下载数据 的时候,速度都是慢慢“冲起来的”
以上就是TCP数据传输的大致流程,虽然并不细致,但是足以描述TCP的工作原理,重点是TCP的流量控制原理,滑动窗口,拥塞窗口,ACK累计确认等知识点。
分享到:
评论

相关推荐

    TCP Sliding Window滑动窗口协议演示动画

    TCP滑动窗口协议是传输控制协议(TCP)中一种重要的流量控制机制,它确保了数据在两个通信端点之间的可靠传输。本动画演示了滑动窗口协议的工作原理,通过Flash技术,用户可以调整参数,直观地理解其动态过程。下面...

    网络学习TCP滑动窗口

    TCP拥塞学习资料,TCP滑动窗口协议,TCP拥塞窗口,网络间对象的传输与调用[new]

    TCP 滑动窗口模拟VC++

    总的来说,TCP滑动窗口模拟VC++项目是一个涉及网络协议、套接字编程、错误处理以及可能的多线程技术的综合性实践,有助于深入理解和应用TCP协议的核心机制。通过这样的实践,你可以更好地掌握网络通信的底层原理,为...

    TCP滑动窗口、流量控制及拥塞控制详解.docx

    TCP 滑动窗口、流量控制及拥塞控制详解 TCP 滑动窗口是 TCP 协议中的一种流量控制机制,它可以控制发送方的发送速度,避免网络拥塞和数据丢失。下面我们将详细介绍 TCP 滑动窗口、流量控制及拥塞控制的原理和机制。...

    11.2.3 TCP 滑动窗口实战 - Wireshark 数据包分析实战(第 3 版) - 知乎书店1

    TCP滑动窗口是一种流量控制机制,用于在TCP连接中管理数据传输的速度,确保接收方能够有效地处理接收到的数据,防止数据丢失或拥塞。在TCP协议中,滑动窗口的概念基于一个可变大小的缓冲区,该缓冲区的大小由发送方...

    TCP滑动窗口演示FLASH

    TCP滑动窗口演示flash,也是转载于其他地方并非原创。

    udt.sdk.3.3.tar.gz_TCP 滑动窗口_UDP 可靠_UDP 滑动窗口_udp 可靠传输_可靠 udp

    TCP滑动窗口协议是TCP传输层协议中的一个重要机制,用于控制发送方的数据速率,防止数据包的拥塞和丢失。TCP滑动窗口基于接收方反馈的确认机制,动态调整发送窗口的大小,确保数据的有序和无损传输。在TCP中,每个...

    tcp滑动窗口和SO-RCVBUF

    tcp滑动窗口和SO_RCVBUFtcp滑动窗口和SO_RCVBUF

    生成树协议及TCP滑动窗口演示

    生成树协议(Spanning Tree Protocol, STP)和TCP滑动窗口是网络通信中的两个重要概念,它们在确保网络稳定性与高效数据传输方面起到关键作用。 生成树协议STP是为了解决局域网(LAN)中可能存在的广播风暴和环路...

    TCP滑动窗口.zip

    大家可能经常听说TCP滑动窗口,那到底什么是TCP滑动窗口呢?今天我就来详细解释下网络开发中常听说的概念:滑动窗口

    TCP滑动窗口协议模拟程序.rar(含程序+源码MFC)

    其中设为1相当于使用后退n帧技术的滑动窗口协议,设为大于1的值则相当于使用选择性重传策略的滑动窗口协议。第2个参数为接收速率设定,编辑框中填入的是接收定时器的间隔时间,单位为ms,1000表示接收速率为每秒处理...

    滑动窗口机制及TCP中的相关实现

    滑动窗口机制是一种在网络通信中实现流量控制的重要技术,尤其在TCP(传输控制协议)中广泛应用。该机制允许发送方在等待接收方确认之前发送多个数据包,从而提高网络效率,但同时也确保了数据的正确顺序接收。 1. ...

    计算机网络原理-119第5章 传输层--TCP滑动窗口技术实现可靠传输.mp4

    计算机网络原理-119第5章 传输层--TCP滑动窗口技术实现可靠传输.mp4

    模拟滑动窗口程序

    采用MFC技术的界面编程,运用C++语言,模拟实现滑动窗口协议。

    滑动窗口机制及TCP中的相关实现.doc

    TCP(传输控制协议)作为一个面向连接的、可靠的、基于字节流的传输层通信协议,通过滑动窗口机制实现了数据的流量控制和拥塞控制,确保了数据的有序传输和传输效率的最大化。 滑动窗口机制的核心在于允许发送方在...

    六、TCP重传、滑动窗口、流量控制、拥塞控制1

    TCP 使用滑动窗口大小作为流量控制的手段,接收方会告诉发送方其当前可以接收的缓冲区大小,发送方据此调整发送速率。 4. **拥塞控制** - 拥塞控制是防止过多的数据同时充斥在网络中,造成网络拥塞。TCP 使用慢...

    计算机网络课件:4_7_5 TCP滑动窗口与差错控制.pptx

    TCP(Transmission ...综上所述,TCP的滑动窗口与差错控制机制是其可靠性的核心,它们通过校验和、确认、超时重传和选择性重传来保证数据的正确传输,同时通过滑动窗口协议实现流量控制,确保数据的高效、稳定流动。

    滑动窗口协议模拟程序

    4. **TCP滑动窗口**:TCP协议使用滑动窗口来实现流量控制和拥塞控制。它的窗口大小不仅取决于接收方的能力,还根据网络状况动态调整。TCP使用慢启动、拥塞避免、快速重传和快速恢复算法来适应网络环境。 滑动窗口...

    使用socket编程模拟滑动窗口协议

    在TCP(传输控制协议)中,滑动窗口协议被用来管理和控制两个通信端点之间的数据传输速率,以防止一方的数据淹没另一方。本项目通过socket编程实现了1bit滑动窗口协议,这将帮助我们深入理解该协议的工作原理。 1. ...

Global site tag (gtag.js) - Google Analytics