【计算机网络笔记】TCP的拥塞控制机制

系列文章目录

什么是计算机网络?
什么是网络协议?
计算机网络的结构
数据交换之电路交换
数据交换之报文交换和分组交换
分组交换 vs 电路交换
计算机网络性能(1)——速率、带宽、延迟
计算机网络性能(2)——时延带宽积、丢包率、吞吐量/率
计算机网络体系结构概念
OSI参考模型基本概念
OSI参考模型中非端-端层(物理层、数据链路层、网络层)功能介绍
OSI参考模型中端-端层(传输层、会话层、表示层、应用层)功能介绍
TCP/IP参考模型基本概念,包括五层参考模型
网络应用的体系结构
网络应用进程通信
网络应用对传输服务的需求
Web应用之HTTP协议(涉及HTTP连接类型和HTTP消息格式)
Cookie技术
Web缓存/代理服务器技术
传输层服务概述、传输层 vs. 网络层
传输层——多路复用和多路分用
传输层——UDP简介
传输层——可靠数据传输原理之Rdt协议
传输层——可靠数据传输之流水线机制与滑动窗口协议
传输层——TCP特点与段结构
传输层——TCP的可靠数据传输
TCP连接管理(图解三次握手和四次挥手)
传输层——拥塞控制原理与解决方法


  • 系列文章目录
  • TCP拥塞控制的基本原理
  • 加性增 —乘性减: AIMD
  • 慢启动: SS
  • 什么时候应该从SS切换到AIMD?
  • TCP拥塞控制算法总结
  • 例题


TCP拥塞控制的基本原理

  • Sender限制发送速率。LastByteSent-LastByteAcked <= CongWin 让发送的最后一个Byte的序列号减去接收的最后一个确认的Byte的序列号小于等于CongWin。这样我们只需要修改CongWin这个值就可以限制发送速率。

    在这里插入图片描述

  • CongWin(拥塞窗口)的大小需要动态地调整。

那需要能够感知和判断网络拥塞。怎么做呢?我们可以定义一个loss事件,当超时或者收到3个重复 ACK时往往意味着网络拥塞了,那发生这个事件的时候就降低速率。

能够感知和判断网络拥塞之后需要合理地调整发送速率。这里有两个机制:

  • 加性增 —乘性减: AIMD
  • 慢启动: SS

下面来看看这两种机制什么意思、怎么做的。

加性增 —乘性减: AIMD

原理

  • 加性增:线性地、逐渐地增加发送速率谨慎探测可用带宽,直到发生loss事件;
  • 乘性减:一旦发生loss事件就要快速地降低速率。

方法:AIMD

  • 加性增:每个RTT 将CongWin增大一个MSS(最大的段的长度)。这种思想是拥塞避免。
  • 乘性减:发生loss后将CongWin减半。

TCP的拥塞控制在运行的时候可能如下图所示,想锯齿一样。

在这里插入图片描述

慢启动: SS

TCP连接建立时,CongWin初始化为1,所以初始的速率很小很保守。那可用的带宽可能远远高于初始速率。那如果这时采用线性增长的话需要很长时间,这就是一种浪费。所以我们希望刚开始增长时候是快速地增长。这样就做到了虽然初始很慢,但是后面可以快速地将速率提高。

所以原理是:

  • 当连接开始时,CongWin指数性增长。
  • 每个RTT 将CongWin翻倍
  • 收到每个ACK进行操作

在这里插入图片描述

什么时候应该从SS切换到AIMD?

这需要依赖Threshold变量。它表示CongWin达到Loss 事件前值的1/2 时。

实现方法:当SS指数性增长达到了Threshold的时候就转变成线性增长AIMD,进入拥塞避免机制。

在这里插入图片描述

更细致的考虑一下Loss事件的处理:

  • 收到3个重复ACKs:把CongWin切到一半,然后然后线性增长。比如上面图中的黑线。
  • 发生Timeout事件:将CongWin直接设为 1 个MSS,然后指数增长,达到threshold 后, 再线性增长。比如上面图中的蓝线。

为什么处理方法不一样呢?因为Timeout事件表明拥塞更严重,那速率就要降地更多。

TCP拥塞控制算法总结

When CongWin is below Threshold, sender in slow-start phase, window grows exponentially;当拥塞窗口小于Threshold时,发送方位于慢启动阶段,拥塞窗口指数增长;

When CongWin is above Threshold, sender is in congestion-avoidance phase, window grows linearly;当拥塞窗口大于Threshold时,发送方位于拥塞避免阶段,拥塞窗口线性增长;

When a triple duplicate ACK occurs, Threshold set to CongWin/2 and CongWin set to Threshold;当收到三个重复ACK时,Threshold 被减为拥塞窗口的一半,拥塞窗口也减半;

When timeout occurs, Threshold set to CongWin/2 and CongWin is set to 1 MSS. 当发生超时时,Threshold减为拥塞窗口的一半,并且拥塞窗口被置为1

下面是一张更细致的图:

在这里插入图片描述

下面是TCP拥塞控制算法伪代码:

在这里插入图片描述

例题

题目:一个TCP连接总是以1 KB的最大段长发送TCP段,发送方有足够多的数据要发送。当拥塞窗口为16 KB时发生了超时,如果接下来的 4 个RTT(往返时间)时间内的TCP段的传输都是成功的,那么当第 4 个RTT时间内发送的所有TCP 段都得到肯定应答时,拥塞窗口大小是多少?

解答:发生超时事件后,threshold会降为拥塞窗口的一半也就是8KB,拥塞窗口CongWin会变为一个MSS最大段长度也就是1KB。这时发送方进入慢启动阶段也就是指数增长阶段,1 个RTT后, CongWin=2 KB,2 个RTT后, CongWin=4 KB ,3 个RTT后, CongWin=8 KB,这时到达threshold值了,所以这时慢启动就结束了,就进入了拥塞避免阶段也就是线性增长阶段,那么再发生一个RTT也就是4 个RTT后, CongWin=9 KB

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

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

相关文章

Linux文件描述符和打开文件之间的关系

简介 文件描述符和打开的文件之间似乎呈现出一一对应的关系。然而&#xff0c;实际并非如此。多个文件描述符指向同一打开文件&#xff0c;这既有可能&#xff0c;也属必要。这些文件描述符可在相同或不同的进程中打开。 要理解具体情况如何&#xff0c;需要查看由内核维护的…

应用安全四十二:SSO安全

一、什么是SSO SSO是单点登录(Single Sign On)的缩写,是指在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。这种方式减少了由登录产生的时间消耗,辅助了用户管理,是比较流行的企业业务整合的解决方案之一。 身份验证过程依赖于双方之间的信任关…

Spring Boot创建多模块项目

创建一个普通的Spring Boot项目, 然后只留下 pom.xml 剩下的都删掉 删除多余标签 标识当前为父模块 创建子模块 删除子模块中多余标签 声明父模块 在父模块中声明子模块

基于JAVA+SSM的房屋租赁系统

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目背景介绍&#xff1a; 随着社会的发展和人们…

【C/C++】什么是POD(Plain Old Data)类型

2023年11月6日&#xff0c;周一下午 目录 POD类型的定义标量类型POD类型的特点POD类型的例子整数类型&#xff1a;C 风格的结构体&#xff1a;数组&#xff1a;C 风格的字符串&#xff1a;std::array:使用 memcpy 对 POD 类型进行复制把POD类型存储到文件中&#xff0c;并从文…

webgoat-(A1)SQL Injection

SQL Injection (intro) SQL 命令主要分为三类&#xff1a; 数据操作语言 &#xff08;DML&#xff09;DML 语句可用于请求记录 &#xff08;SELECT&#xff09;、添加记录 &#xff08;INSERT&#xff09;、删除记录 &#xff08;DELETE&#xff09; 和修改现有记录 &#xff…

【自我提升】项目升级-Beyond Compare效率工具

写在前面&#xff1a;最近接手一个项目&#xff0c;这个项目集成了许多开源项目&#xff0c;其中我需要对其中一个开源项目进行升级操作。在此记录升级过程和心得&#xff0c;希望可以给各位道友提供一种思路&#xff0c;同时也希望道友有更好的办法能分享在评论区。 项目场景 …

RabiitMQ消息队列系统

一、MQ 1、概念&#xff1a; MQ 全称为 Message Queue (消息队列)&#xff0c;是一种应用程序对应用程序的通信方法。MQ 允许应用程序将消息写入队列&#xff0c;其他应用程序从队列中读取并处理这些消息&#xff0c;不需要它们之间直接相互联系。消息队列可用于实现异步通信…

idea Error: java: OutOfMemoryError: insufficient memory处理

IDEA设置里&#xff0c;修改heap size更大一点&#xff0c;可以解决问题

apachesolr启动带调试

这里solr.cmd报错&#xff0c;报错原因是java版本问题&#xff0c;后面发现这是因为多个java版本导致读取java_home失败&#xff0c; 那么我们修改solr.cmd中的JAVA_HOME为SOLR_JAVA_HOME IF DEFINED SOLR_JAVA_HOME set "JAVA_HOME%SOLR_JAVA_HOME%"环境变量将SOLR…

【Python基础】史上最全||一篇博客搞懂Python面向对象编程(封装、继承、多态)

Python面向对象编程 1.面向对象概念介绍1) 面相过程 —— 怎么做&#xff1f;2&#xff09;面向对象 谁来做 2.类和对象2.1类2.2对象2.3类和对象的关系2.4类的设计2.5面向对象设计案例 士兵类设计2.6身份运算符 3.私有属性和私有方法3.1. 应用场景及定义方式 4.继承、多态重写父…

2014年亚太杯APMCM数学建模大赛C题公共基础课教师专业化培养方式研究求解全过程文档及程序

2014年亚太杯APMCM数学建模大赛 C题 公共基础课教师专业化培养方式研究 原题再现 近年来&#xff0c;世界基础工业、信息产业、服务业的跨越式发展引发了大量人才需求&#xff0c;导致了职业教育的飞速发展&#xff0c;除原有专科层次高等职业教育院校外&#xff0c;大量普通…

24PL-18-50-1836、12PN-4.1-50-1836比例电磁铁控制器

12PG-2.2-40-1836、24PG-8.8-40-1836、12PT-40-1836、24PT-40-1836、12PL-2.2-40-1836、24PL-8.8-40-1836、12PN-2.2-40-1836、24PN-8.8-40-1836、12PG-4.1-50-1836、24PG-18-50-1836、12PT-4.1-50-1836、24PT-18-50-1836、12PL-4.1-50-1836、24PL-18-50-1836、12PN-4.1-50-183…

基于8086汽车智能小车控制系统

**单片机设计介绍&#xff0c;基于8086汽车智能小车控制系统 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于 8086 的汽车智能小车控制系统是一种将微处理器技术应用于汽车控制的系统。下面是其主要的设计介绍&#xff1a; 硬…

大数据学习之Spark性能优化

文章目录 Spark三种任务提交模式宽依赖和窄依赖StageSpark Job的三种提交模式 Shuffle机制分析未优化的Hash Based Shuffle优化后的Hash Based ShuffleSort-Based Shuffle Spark之checkpointcheckpoint概述checkpoint与持久化的区别checkPoint的使用checkpoint源码分析 Spark程…

Django实战项目-学习任务系统-发送短信通知

接着上期代码内容&#xff0c;继续完善优化系统功能。 本次增加发送短信通知功能&#xff0c;学习任务系统发布的任务&#xff0c;为了更加及时通知到学生用户&#xff0c;再原有发送邮件通知基础上&#xff0c;再加上手机短信通知功能。 第一步&#xff1a;开通短信通知服务…

Docker容器中执行throttle.sh显示权限报错:RTNETLINK answers: Operation not permitted

在模拟通信环境时&#xff0c;我执行了一下命令&#xff1a; bash ./throttle.sh wan但是&#xff0c;出现了权限的报错&#xff1a;RTNETLINK answers: Operation not permitted 解决方案说简单也挺简单&#xff0c;只需要两步完成。但是其实又蛮繁琐&#xff0c;因为需要将…

正点原子嵌入式linux驱动开发——Linux 4G通信

前面学习了如何在Linux中使用有线网络或者WIFI&#xff0c;但是使用有线网络或者WIFI有很多限制&#xff0c;因为要布线&#xff0c;即使是WIFI也得先布线&#xff0c;然后再接个无线路由器。有很多场合是不方便布线的&#xff0c;这个时候就是4G大显身手的时候&#xff0c;产品…

答题小程序排位pk答题怎么玩

答题小程序排位PK答题升级赛是一个备受喜爱的功能&#xff0c;它不仅增加了用户之间的互动和竞争&#xff0c;同时也为答题小程序增添了更多的趣味性和挑战性。那么&#xff0c;如何参与答题小程序的排位PK答题升级赛呢&#xff1f;本文将详细介绍答题小程序的排位PK答题升级赛…

关于打包css找不到报错

背景&#xff1a;最近公司产品升级为v3项目&#xff0c;打包总是报css缺失 问题&#xff1a;报错提示如下&#xff0c;找不到css 出现原因分析&#xff1a;由于项目比较老&#xff0c;很多人写的&#xff0c;代码风格不统一导致的&#xff0c;比如父组件A使用<style><…