当前位置: 首页 > news >正文

计算机网络-- TCP

目录

1.TCP的流量控制

2. TCP的拥塞控制

1.TCP的流量控制

一般来说,我们总是希望数据传输得更快一些。

但如果发送方把数据发送得过快,接收方就可能来不及接收,这就会造成数据的丢失。

所谓流量控制(flow control)就是让发送方的发送速率不要太快,要让接收方来得及接收。

利用滑动窗口机制可以很方便地在TCP连接上实现对发送方的流量控制。

  • TCP接收方利用自己的接收窗口的大小来限制发送方发送窗口的大小。
  • TCP发送方收到接收方的零窗口通知后,应启动持续计时器。持续计时器超时后,向接收方发送零窗口探测报文。

2. TCP的拥塞控制

在某段时间,若对网络中某一资源的需求超过了该资源所能提供的可用部分,网络性能就要变坏。这种情况就叫做拥塞(congestion)。

在计算机网络中的链路容量(即带宽)、交换结点中的缓存和处理机等,都是网络的资源。

出现拥塞而不进行控制,整个网络的吞吐量将随输入负荷的增大而下降。

下面介绍四种拥塞控制算法的基本原理,假定如下条件:

  1. 数据是单方向传送,而另一个方向只传送确认。
  2. 接收方总是有足够大的缓存空间,因而发送方发送窗口的大小由网络的拥塞程度来决定。
  3. 以最大报文段MSS的个数为讨论问题的单位,而不是以字节为单位。

发送方维护一个叫做拥塞窗口cwnd的状态变量,其值取决于网络的拥塞程度,并且动态变化。
拥塞窗口cwnd的维护原则:只要网络没有出现拥塞,拥塞窗口就再增大一些;但只要网络出现拥塞,拥塞窗口就减少一些。
判断出现网络拥塞的依据:没有按时收到应当到达的确认报文(即发生超时重传)。
发送方将拥塞窗口作为发送窗口swnd,即swnd=cwnd。

维护一个慢开始门限ssthresh状态变量:
当cwnd<ssthresh时,使用慢开始算法;
当cwnd>ssthresh时,停止使用慢开始算法而改用拥塞避免算法;
当cwnd=ssthresh时,既可使用慢开始算法,也可使用拥塞避免算法。

慢开始和拥塞避免算法是1988年提出的TCP拥塞控制算法(TCP Tahoe版本)。
1990年又增加了两个新的拥塞控制算法(改进TCP的性能),这就是快重传和快恢复(TCP Reno版本)。

  • 有时,个别报文段会在网络中丢失,但实际上网络并未发生拥塞。
  • 这将导致发送方超时重传,并误认为网络发生了拥塞;
  • 发送方把拥塞窗口cwnd又设置为最小值1,并错误地启动慢开始算法,因而降低了传输效率。

采用快重传算法可以让发送方尽早知道发生了个别报文段的丢失。

所谓快重传,就是使发送方尽快进行重传,而不是等超时重传计时器超时再重传。

  • 要求接收方不要等待自己发送数据时才进行捎带确认,而是要立即发送确认;
  • 即使收到了失序的报文段也要立即发出对已收到的报文段的重复确认
  • 发送方一旦收到3个连续的重复确认,就将相应的报文段立即重传,而不是等该报文段的超时重传计时器超时再重传。
  • 对于个别丢失的报文段,发送方不会出现超时重传,也就不会误认为出现了拥塞(进而降低拥塞窗口cwnd为1)。使用快重传可以使整个网络的吞吐量提高约20%。

发送方一旦收到3个重复确认,就知道现在只是丢失了个别的报文段。于是不启动慢开始算法,而执行快恢复算法;
发送方将慢开始门限ssthresh值和拥塞窗口cwnd值调整为当前窗口的一半;开始执行拥塞避免算法。
也有的快恢复实现是把快恢复开始时的拥塞窗口cwnd值再增大一些,即等于新的ssthresh+3。

  • 既然发送方收到3个重复的确认,就表明有3个数据报文段已经离开了网络;
  • 这3个报文段不再消耗网络资源而是停留在接收方的接收缓存中;
  • 可见现在网络中不是堆积了报文段而是减少了3个报文段。因此可以适当把拥塞窗口扩大些。
http://www.jsqmd.com/news/117998/

相关文章:

  • Excalidraw差分同步原理:精准同步每一处改动
  • Excalidraw灾备方案:确保关键业务连续性
  • 1、脚本编程入门指南
  • Excalidraw最终一致性模型:保障数据完整性
  • Excalidraw享元模式共享:节省内存资源
  • Excalidraw手势操作优化:触控板使用更顺手
  • Excalidraw SLA保障:企业级服务可用性承诺
  • 2、脚本编程入门指南
  • Excalidraw迭代器模式遍历:集合元素逐个访问
  • 无人机滑坡分割数据集 无人机自然灾害实例分割检测数据集 YOLOV8 SEG分割模型如何训练无人机滑坡落石实例分割数据集
  • 3、脚本编程与Windows Script Host 5.6新特性全解析
  • 11.Python 常用数据类型「增删改查」操作总结表格
  • Excalidraw双因素认证:强化账户登录安全性
  • Excalidraw工厂模式实现:对象创建更加优雅
  • Excalidraw API自动化脚本:批量创建模板库
  • Excalidraw单例模式应用:全局状态统一管理
  • Excalidraw备忘录模式保存:内部状态随时还原
  • 4、WSH 5.6 新特性全解析
  • 21、脚本编程及相关技术全面解析
  • Excalidraw权限管理最佳实践:保障企业信息安全
  • 包头型材2025年口碑推荐榜出炉 - 2025年品牌推荐榜
  • Excalidraw乐观锁机制:提升并发编辑体验
  • 2025年12月江苏新沂条纹砖服务商Top 5榜单解析 - 2025年品牌推荐榜
  • Excalidraw缓存策略设计:减少重复计算开销
  • 15、深入探索 Active Directory 搜索:优化策略与实用技巧
  • Excalidraw语音输入实验:边说边画的未来已来
  • NUC970 SoC Linux BSP架构深度分析 - 第一部分:总体架构与设计模式
  • 详细介绍:LeetCode 每日一题笔记 日期:2025.11.23 题目:1262.可被三整除的最大和
  • 16、活动目录搜索全解析
  • Excalidraw鼠标右键菜单:快捷入口提高效率