中科大计网学习记录笔记(十七):拥塞控制原理 | TCP 拥塞控制

news2024/12/21 21:51:57

前言:

学习视频:中科大郑烇、杨坚全套《计算机网络(自顶向下方法 第7版,James F.Kurose,Keith W.Ross)》课程
该视频是B站非常著名的计网学习视频,但相信很多朋友和我一样在听完前面的部分发现信息量过大,有太多无法理解的地方,在我第一次点开的时候也有相同的感受,但经过了一段时间项目的学习,对计网有了更多的了解,所以我准备在这次学习的时候做一些记录并且加入一些我的理解,希望能够帮助到大家。
往期笔记可以看专栏中的内容😊😊😊

文章目录

      • 3.6 拥塞控制原理
        • 3.6.1 什么是拥塞?
        • 3.6.2 拥塞的原因 / 代价
          • <1> 场景 1:理想情况 - 无限缓冲区
          • <2> 场景二 - 有限缓冲区
          • <3> 场景三 - 网络死锁的情况
        • 3.6.3 两种拥塞控制的方法
        • 3.6.4 案例 - ATM ABR 拥塞控制
      • 3.7 TCP 拥塞控制
        • 3.7.1 拥塞控制要解决的几个问题
        • 3.7.2 拥塞感知
        • 3.7.3 速率控制方法
        • 3.7.4 TCP 拥塞控制
        • 3.7.5 总结:TCP 拥塞控制
        • 3.7.6 TCP 的公平性

3.6 拥塞控制原理

3.6.1 什么是拥塞?

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

💡 当 网络中的流量 超过了网络资源的处理能力时,就会发生拥塞,导致数据包丢失、延迟增加和带宽利用率下降。

  • 拥塞是指网络中出现了过多的数据流量,导致网络设备(如路由器、交换机)无法及时处理所有传入的数据包,进而 导致缓冲队列溢出,丢包等问题。
3.6.2 拥塞的原因 / 代价
<1> 场景 1:理想情况 - 无限缓冲区

👉 这里探讨的是理论化的情况

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

💡 假设有两个发送端和两个接收端,有一个路由器,其输出缓冲区无限大,也就是不会存在丢失的情况,输出链路的带宽为 R,且不考虑输入时处理的情况。

💡 且在 TCP 的情况下会 尽可能的让 每个连接分到的带宽相同,所以这里假设这两个连接 平分 带宽;也就是每个连接能够达到的最大带宽为 R / 2

💡 且发送方 不会重传

有了这些先决条件,来看看连接的吞吐量和延迟:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

💡 吞吐量(Throughput)是指在单位时间内通过网络或系统的数据量或信息量。

当进入的速率总和达到 R 的时候,排队延迟会趋向无穷大,因为带宽是理论上可达到的最大速率,但实际是不可能实现的,所以队列会一直累计,但因为队列是无线大的,分组并不会 丢失 且发送方不会重传,所以有效的泵出和输入是相等的。

<2> 场景二 - 有限缓冲区

👉 这里讨论的是偏向于现实的情况

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

💡 缓冲区不是无限的,分组会丢失

💡 发送方会因为超时而重发分组

当泵入的数据量不断的增大,由于延迟的增大会触发重传机制,这就导致有效的泵入逐渐减少,会包含很多重发的泵入,这也就导致了有效泵出的减少。

最终呈现出来的图像是这样的:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这也就导致了发送方需要大量的重发才能保证有效的泵入。比如说为了达到 1.0 的泵出量,有可能需要 1.2 的泵入量,如果不加以控制的话会导致重发越来越多,拥塞的程度也越来越大,是一个 正反馈的情况。

<3> 场景三 - 网络死锁的情况

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

💡 四个发送端 且 存在超时重传机制

💡 多重路径

当红色的泵入增加的时候,蓝色的泵入在最上方的路由中被抛弃了,因为它到该路由多一跳,到达的更慢;同理,其他的各个路由器都会由于这种情况而形成阻塞。最终导致网络的整体泵出量为 0,达到一个死锁的情况。

3.6.3 两种拥塞控制的方法

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

🍀 端到端的拥塞控制:没有来自网络的直接显示其拥塞状况的信息,系统根据延迟和丢失的时间来判断网络的拥塞程度,比如 TCP 的快速重发,当 TCP 收到三个冗余 ACK 的时候就说明分组可能丢失了,这时候就可以降低发送速率,这也是 TCP 采用的拥塞控制方法。

🍀 网络辅助的拥塞控制:即发送端可以接收到网络关于其拥塞程度的反馈,这样做拥塞控制就会简单很多,比如下面提到的 ATM 网络。

3.6.4 案例 - ATM ABR 拥塞控制

💡 ATM(Asynchronous Transfer Mode)异步传输模式,不是取款机(大悲)

💡 ABR(Available Bit Rate),可用比特率,是一种ATM(异步传输模式)网络中的一种拥塞控制服务类型。这种服务会根据网络的拥塞程度动态调整数据传输速率,以确保网络中的可用带宽得到最佳利用,同时避免网络拥塞和数据丢失。

在这种网络结构上传输的数据称为 信元,信元中有一种特殊的信源为 RM(资源管理)信元,其由发送端发送,在数据信元中间隔插入。

当经过交换机时,交换机会根据自己目前的状况来调整资源管理信元的信息

  • NI bit:no increase in rate 轻微拥塞的时候请求速率不要再增加
  • CI bit:congestion indication 拥塞指示,表示该路由器出现拥塞,应该减小到最小速率。

接收端接收到数据信元后将 RM 信元直接返回 不做任何改变;接收端收到后就可以知道这条通路中的拥塞情况。

3.7 TCP 拥塞控制

3.7.1 拥塞控制要解决的几个问题

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

🍀 端到端的拥塞控制机制:路由器不会向端主机提供拥塞的相关信息

  • 这样的好处是会降低路由器的负担,符合是网络核心简单的 TCP/IP 架构原则
  • 端系统根据自己得到的信息来判断是否发生拥塞从而采取动作

❓ 拥塞控制需要解决的问题

  • 如何检测是否出现拥塞和拥塞的程度如何?
  • 在拥塞的时候发送应该采取什么策略来降低?
  • 在拥塞缓解的时候如何增加速率来保证信息交换的速度?
3.7.2 拥塞感知

💡 既然路由器不提供拥塞情况,那发送端如何得知是否产生拥塞呢?

🍀 当某个段超时的时候,说明网络在传输过程中丢失了

  • 原因一:由于路由器队列已满,出现丢弃的情况
  • 原因二:传输过程中出现了乱序的情况,导致信息没有通过校验而被丢失
  • 由于第二种情况相较于第一种情况出现频率低很多,所以对拥塞控制产生的影响不大

🍀 当出现三个冗余的 ACK 的时候,也可以说明分组被丢失

3.7.3 速率控制方法

💡 拥塞窗口(Congestion Window,简称CongWin)是TCP拥塞控制算法中的一个重要概念,用于控制发送方发送数据的速率,以便避免网络拥塞和提高网络性能。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

👉 拥塞窗口的大小是由 TCP 拥塞控制算法 动态 调整的。

👉 超时的时候拥塞窗口变为 1MSS,进入 SS 阶段,然后倍增到拥塞窗口的一半后进入 CA 阶段

  • 当收到三个冗余的 ACK,拥塞窗口变为一半再次进入 CA 阶段

👉 当正常收到 ACK 没有发生以上两种情况的时候

  • SS 阶段(Slow Start,慢启动阶段):每个往返延迟(RTT)成倍增加发送报文量
  • CA 阶段(Congestion Avoidance,拥塞避免阶段):每个 RTT 只会增加一个单位

💡 在这里有一个基本的概念即可,后面会详细讲述 TCP 拥塞控制的整个流程。

💡 TCP 流量控制和拥塞控制是一个 联合的动作,即发送时要同时满足这两个的要求

3.7.4 TCP 拥塞控制

🍀 慢启动(Slow Start)阶段

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • 当连接建立或者网络从拥塞中恢复时,拥塞窗口被初始化为一个较小的值,通常为一个 MSS。
  • 在慢启动阶段,发送方逐渐增加拥塞窗口的大小。每当收到一个确认 ACK 时,拥塞窗口大小就会加倍,这样拥塞窗口呈指数增长。

💡 这样做的目的是快速 探测 网络的可用带宽,以便尽快利用网络资源。

🍀 拥塞避免阶段

  • 当拥塞窗口大小大于阈值的时候,就会进入拥塞避免的阶段,此时每一个 RTT 拥塞窗口加 1,而不是像慢启动一样成倍的增加的增加
  • 拥塞避免阶段就是在临界值上进行试探直到出现了冗余 ACK 或者丢失的情况

🍀 快速重传和超时重传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • 当出现快速重传的时可以推断出网络出现了轻微的拥塞,此时将拥塞窗口减半,继续进行 CA 阶段
  • 如果出现超时则说明拥塞情况较差,此时将阈值设定为发生拥塞时窗口值的一半,同时拥塞窗口被设定为 1 MSS,进行 SS 阶段。
  • 如上图中的红色部分就代表了发生超时进行慢启动,其余部分均为冗余 ACK 导致的拥塞窗口减半。

💡 在这个流程中影响的因素主要是阈值和超时以及冗余 ACK,搞清楚对于这三种情况如何处理即可梳理好整个流程:

  • 阈值是慢启动和拥塞避免的分水岭
  • 超时会导致从慢启动开始且会导致阈值的调整
  • 冗余 ACK 会导致拥塞窗口的减少

💡 由于慢启动在整个流程中所占的时间较短,所以整体是呈现锯齿状的,即由于冗余 ACK 的作用导致的拥塞窗口减半。

3.7.5 总结:TCP 拥塞控制

💡 名词解释:

  • CongWin:Congestion Window,拥塞窗口
  • Threshold:阈值

🍀 当 CongWin < CongWin ,发送端处于 慢启动 阶段,窗口指数增长

🍀 当 CongWin > CongWin,发送端处于 拥塞避免 阶段,窗口线性增长

🍀 当收到三个重复 ACK的时候,Threshold 设置成 CongWin / 2CongWin = Threshold + 3

🍀 当超时时间发生的时候,Threshold = CongWin / 2CongWin = 1 MSS,进入 SS 阶段

💡 补充:TCP 的吞吐量:TCP 的平均吞吐量可以用窗口尺寸和 RTT 来近似的描述

  • 假设发生丢失的时候窗口尺寸是固定的

  • 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • 平均窗口尺寸 = 1 / 2 W + W = 3 / 4 W 平均窗口尺寸 = 1 / 2 W + W = 3 / 4 W 平均窗口尺寸=1/2W+W=3/4W

  • 吞吐量等于上述值除以 RTT

3.7.6 TCP 的公平性

💡 公平性目标:如果 K 个 TCP 绘画共享一个链路带宽为 R 的瓶颈,每个会话分到的有效带宽均为 R / K。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

TCP 通过其拥塞控制可以实现相对的公平性

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

上图中紫色的线代表带宽,即链接一所占的带宽加上链接二所占的带宽等于总带宽,也即出现拥塞的时候。

  • 左下角的红色线很明显可以看出来当到达拥塞的时候 链接一 所占有的资源多
  • 因为拥塞窗口为对半减少,这样就代表 占有资源多的一方减半时候损失的也就越多
  • 这样会逐渐靠近虚线,也就是连接一所占的带宽等于连接二所占的带宽的情况,这样就达到了公平性

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1487503.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VulnHub打靶记录——Socnet

靶机下载地址&#xff1a;https://www.vulnhub.com/entry/boredhackerblog-social-network,454/ 将靶机设置为NAT模式并启动。 主机发现&信息收集 靶机和 kali 在同一网段&#xff0c;使用nmap扫描网段主机&#xff0c; nmap 192.168.50.1/24其中192.168.50.130是本机&…

UV画贴图时如何去掉一部分

1.纹理先选psd 2. altshift 把要去掉的中选中 选择几何体-隐藏选择

图像增强技术总结

最近科研需要改进算法&#xff0c;需要先对图像进行增强后处理&#xff0c;所以对图像增强技术做一个总结。图像增强的目的就是要提高图像的质量&#xff0c;在图像处理中&#xff0c;有两种提高图像质量的方法&#xff1a;一是图像在采集的过程中&#xff0c;知道图像质量降低…

春招!启动了

大家好&#xff0c;我是洋子。今年的春招很多企业已经开始招聘了&#xff0c;像美团今年继续发力&#xff0c;24届春招以及25届暑期转正实习一共招聘4000人。另外&#xff0c;阿里&#xff0c;京东&#xff0c;顺丰等公司也已经开始春招&#xff0c;可以说招聘的号角已经正式吹…

C语言——指针的进阶——第1篇——(第26篇)

坚持就是胜利 文章目录 一、字符指针1、面试题 二、指针数组三、数组指针1、数组指针的定义2、&数组名 VS 数组名3、数组指针的使用&#xff08;1&#xff09;二维数组传参&#xff0c;形参是 二维数组 的形式&#xff08;2&#xff09;二维数组传参&#xff0c;形参是 指针…

Redis高可用性【重点】

参考链接 https://xiaolincoding.com/redis/cluster/master_slave_replication.html#%E7%AC%AC%E4%B8%80%E6%AC%A1%E5%90%8C%E6%AD%A5 高可用性 主从复制哨兵节点 主从复制 【面试题】 Redis主从节点时长连接还是短连接&#xff1f; 长连接 #怎么判断 Redis 某个节点是否正常…

【C++从练气到飞升】01---C++入门

&#x1f388;个人主页&#xff1a;库库的里昂 ✨收录专栏&#xff1a;C从练气到飞升 &#x1f389;鸟欲高飞先振翅&#xff0c;人求上进先读书。 目录 推荐 前言 什么是C C的发展史 &#x1f4cb;命名空间 命名空间定义 命名空间使用 命名空间的嵌套 std命名空间的使用 &#…

Windows Server 各版本搭建文件服务器实现共享文件(03~19)

一、Windows Server 2003 打开服务器&#xff0c;点击左下角开始➡管理工具➡管理您的服务器➡添加或删除角色 点击下一步等待测试 勾选自定义配置&#xff0c;点击下一步 选择文件服务器&#xff0c;点击下一步 勾选设置默认磁盘空间&#xff0c;数据自己更改&#xff0c;最…

【js】事件循环之promise的async/await与setTimeout

什么是事件循环 事件循环又叫消息循环&#xff0c;是浏览器渲染主线程的工作方式。 浏览器开启一个永不停止的for循环&#xff0c;每次循环都会从消息队列中取任务&#xff0c;其他线程只需要在合适的时候将任务加入到消息队列的末尾。 过去分为宏任务和微任务&#xff0c;现…

数据分析工具在不同行业中有什么不同的需求?

数据建模也是数据分析的一个分支 一、交管行业&#xff0c;对于数据建模的需求如下 1、根据分析方法可以将交管大数据模型分为统计分析类、业务规则类、预测预警类、异常分析类、画像分析类和综合评价类六大类&#xff0c;具体如下&#xff1a; 2、模型的实现过程 二、各类工…

写时复制简介

写时复制技术(Copy on Write)是比较常用的一种技术&#xff0c;它的主要目的是延迟减少以及延迟内存的分配&#xff0c;增加执行效率&#xff0c;只有在真正进行写操作的过程中才会真正分配物理资源。同时&#xff0c;也可以保护数据在系统崩溃时出现的丢失。比如&#xff0c;我…

视频云平台——搭建SRS5平台支持GB28181视频流的推送

&#x1f4e2;欢迎点赞 &#xff1a;&#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff0c;赐人玫瑰&#xff0c;手留余香&#xff01;&#x1f4e2;本文作者&#xff1a;由webmote 原创&#x1f4e2;作者格言&#xff1a;新的征程&#xff0c;我们面对的不仅…

逆向案例四:360k静态和精灵数据动态AES解密,用js的方法

一、360K 网页链接:https://www.36kr.com/p/2672600261670407 页面中有静态的需要解密的内容&#xff0c;确定html包&#xff0c;确定方法 1.1方法步骤 在下方的搜索中输入decrypt(或者关键字window.initialState &#xff0c;进入js文件 在AES.decrypt处打上断点&#xff0…

MySQL面试题-事务(答案版)

事务 1、事务与存储引擎的关系 事务是由 MySQL 的引擎来实现的&#xff0c;我们常见的 InnoDB 引擎它是支持事务的。 不过并不是所有的引擎都能支持事务&#xff0c;比如 MySQL 原生的 MyISAM 引擎就不支持事务&#xff0c;也正是这样&#xff0c;所以大多数 MySQL 的引擎都…

hnust 湖南科技大学 2023 综合实训3(软件工程)课设 完整代码及数据库+报告+uml等图源文件+指导书

hnust 湖南科技大学 2023 综合实训3&#xff08;软件工程&#xff09;课设 完整代码及数据库报告uml等图源文件指导书 介绍 老师考核等级为优&#xff0c;系统多次测试&#xff0c;未发现bug 项目前后端分离&#xff0c;前端vue2工程项目&#xff0c;后端springboot&#xff…

知乎语音下载(mediadown)

知乎语音下载(mediadown) 一、介绍 知乎语音下载,能够帮助你下载知乎知学堂课程中的语音和视频。它不能帮你越过会员权限,下载你没权限访问的语音和视频。 二、下载地址 本站下载:知乎语音下载(mediadown) 百度网盘下载:知乎语音下载(mediadown) 三、安装教程 …

创业者的智选:知识付费小程序定制开发服务解析

探索知识付费领域的新时代&#xff0c;选择专业的知识付费小程序定制开发服务&#xff0c;打造个性化、高效的知识传播平台。无论您是企业、机构还是个体创作者&#xff0c;都能助您成功变现知识资产。 知识付费小程序的开发是一个涉及多方面技术的综合性工程。下面提供一些关…

利用redis实现秒杀功能

6、秒杀优化 这个是 图灵 的redis实战里面的一个案例 6.1 秒杀优化-异步秒杀思路 我们来回顾一下下单流程 当用户发起请求&#xff0c;此时会请求nginx&#xff0c;nginx会访问到tomcat&#xff0c;而tomcat中的程序&#xff0c;会进行串行操作&#xff0c;分成如下几个步骤…

Linux:Kubernetes(k8s)基础理论笔记(1)

我笔记来源的图片以及共享至GitHub&#xff0c;本章纯理论。这是k8s中部分的基础理论 &#x1f447; KALItarro/k8spdf: 这个里面只有一个pdf文件 (github.com)https://github.com/KALItarro/k8spdf&#x1f446; 什么是kubernetes kubernetes 是一个开源的&#xff0c;用于管…

二、TensorFlow结构分析(1)

目录 1、TF数据流图 1.1 TensorFlow结构分析 1.2 案例 2、图与TensorBoard 2.1 图结构 2.2 图相关操作 2.2.1 默认图 2.2.2 创建图 2.3 TensorBoard&#xff1a;可视化学习 2.3.1 数据序列化 - events文件 2.3.2 启动TensorBoard 2.4 OP 2.4.1 常见OP 2.4.2 指令…