网络编程——TCP的特性之自动重传/流量控制/拥塞控制,一篇说清楚

文章目录

    • 1. ARQ自动重传协议
      • 1.1 停止等待ARQ
      • 1.2 连续ARQ
      • 1.3 总结
    • 2. TCP的流量控制
    • 3. TCP的拥塞控制
      • 3.1 慢开始算法
      • 3.2 拥塞避免算法
      • 3.3 快重传算法
      • 3.4 快恢复算法

1. ARQ自动重传协议

自动重传请求(Automatic Repeat-reQuest),通过使用确认和超时这两个机制,在不可靠服务的基础上实现可靠的信息传输,其中包括停止等待ARQ协议和连续ARQ协议

1.1 停止等待ARQ

发送窗口大小为1,接收窗口大小也为1
发送方每发送一个数据包,就要等待接收方返回ack包,如果在定时时间内没收到ack包,则需要重新发送,而这个超时时间,是需要经过RTT往返时延(从发送方发送数据开始,到发送方接收到来自接收方的确认消息)来计算出来的。

当数据正常传输时,发送完M1数据包后,等待接收方的M1数据包ACK,收到后继续发送M2数据包并等待ACK
image.png

当数据传输出错时,假设数据包M1丢失,则一定超时时间后,进行一次重传。
image.png

1.2 连续ARQ

连续ARQ发送方可连续发送多个分组的数据,而不需要像停止等待ARQ一样,等到应答再进行发送,大大提升带宽的利用率。
image.png

1)滑动窗口概念
滑动窗口协议在发送方和接收方之间各自维持一个滑动窗口,两个窗口大小不一定相同。
主要提供TCP的可靠性(基于确认重传机制)以及TCP的流控特性(控制网络传输时的流量,避免拥塞发生)。

滑动窗口其实类似一个收费站,收费站也就是窗口的位置是不变的,数据不停的在进行滑动。
image.png

2)滑动窗口重发机制
发送端维护一个窗口,窗口内有多个分组,分组个数等于窗口的大小,窗口内的分组可以直接连续发送数据,不需要等待接收端返回的ACK,这样可以提升对信道的利用率。

TCP协议提供两种滑动窗口协议:回退(Go-Back-N)以及选择重传(Selective Repeat来解决连续ARQ模式下传输数据出错的问题。
1)回退(Go-Back-N)协议
发送窗口大小 n > 1,接收窗口 = 1,当发生数据丢失时,会重传所有大于最后一个ACK的包
image.png
在这种模式下,发送端会维护一块发送端的数据缓存,当需要重发窗口中的分组报文,便会从缓存里读取数据发送。
这里采用的是累计确认的形式,不像停止等待ARQ,现在不需要对数据帧进行逐个的确认,而是对按序到达的最后一个分组进行确认,假设发送方发送了5个包,但是第三个包丢失,则接收方只返回前两个包的ACK,此时发送方因为不知道后面的三个包有没有发送成功,只能选择这三个包进行重传。
2)选择重传(Selective Repeat)协议
发送窗口大小 > 1,接收窗口大小 > 1,当发生数据丢失,只重传丢失的数据包。
此时已经无法依赖ACK包去做选择重传了,因为ACK只能表示收到了哪些包,但中间的包丢失时,则无法表示。
所以在这里引入了SACK**(Selective Acknowledgement)**,存储在TCP头部的可变选项中,记录接收窗口缓存中还未收到的数据包信息。
image.png
具体例子如下:
image.png

1.3 总结

协议窗口大小是否有序接收具体做法
停止等待ARQ发送=1, 接收=1有序发送窗口每次只能发送一个数据包,然后就停止等待ack包。接收窗口有序的接收数据包,接收成功后发送ack包给发送窗口,如果收到的数据包是无序的,就直接丢弃
连续ARQ-回退协议发送 = N,接收 = 1有序发送窗口每次最多一次性发送n个数据包,接收窗口有序的接收数据包,当接收到有序的数据包后,发送ack包给发送窗口,如果收到的数据包时无序的,就直接丢弃。当数据包丢失的时候,会将发送窗口中的后面的所有数据包都重新发送
连续ARQ-选择重传协议发送 = N,接收 = N无序发送窗口每次最多一次性发送n个数据包,接收窗口无序的接收数据包,当接收到数据包后,发送ack包给发送窗口,ack中会携带SACK信息,也就是接收窗口中的缓存信息。发送端会根据SACK信息来只重传丢失的数据包

2. TCP的流量控制

目的:防止分组丢失进而触发自动重传机制,造成网络流量的浪费。

原理:如果发送者发送数据过快,接收者来不及接收,那么就会有数据分组丢失。为了避免这种分组丢失,接收端会通知发送端它的接收窗口大小(TCP首部中有一个窗口大小值),此时发送者也将发送窗口大小更改为这个值,让接收者来得及接收。

具体案例:假设一开始主机A和B的窗口都是400,那么在发送时,主机A会连续发送400个字节的数据,如果201~300号意外丢失了,主机B会返回响应ACK=1,ack=201,rwnd=300,这表示主机B已接收到201号之前的数据,并将自己的接收窗口设置为300。此时A收到后将发送窗口大小也设置为300,达到流量控制的目的。

3. TCP的拥塞控制

目的:防止过多的数据注入到网络中,避免出现网络负载过大的情况,常用的算法就是:
慢开始、拥塞避免、快重传、快恢复

原理:发送方维持一个拥塞窗口cwnd(congestion window)的状态变量,拥塞窗口的大小取决于网络的拥塞程度,并且动态地在变化。另外考虑到接受方的接收能力 发送方的发送窗口小于或等于拥塞窗口

3.1 慢开始算法

原理:一开始不发送大量的数据,防止网络负载过大,由小到大逐渐增加拥塞窗口的大小,来探测网络的拥塞程度

具体案例:发送方每次经过一个传输轮次之后,拥塞窗口cwnd就直接加倍,这样比直接一下把许多报文注入网络要慢的多。
image.png

3.2 拥塞避免算法

原理:当拥塞窗口cwnd到达慢开始门限ssthresh后,让拥塞窗口缓慢增长,每经过一个传输轮次后,将cwnd值加一,而不是直接加倍。使cwnd已经到达一定值的情况下,网络不容易出现阻塞。

慢开始门限ssthresh与拥塞窗口cwnd的关系
当cwnd<ssthresh时,使用慢开始算法
当cwnd>ssthresh时,改用拥塞避免算法
当cwnd=ssthresh时,慢开始与拥塞避免算法任意

具体案例:拥塞窗口cwnd初始值为1,慢开始门限ssthresh初始值是16
1)在cwnd<ssthresh,执行慢开始算法,cwnd的值在经过一个轮次传输后值翻倍
2)当cwnd>ssthresh,执行拥塞避免算法,每一个轮次,cwnd的值只加1
3)当cmnd = 24时,假设发生网络阻塞,将进行”乘法减小“,ssthresh = cwnd / 2,cwnd为0,重新开始慢开始算法
image.png

3.3 快重传算法

原理:快速进行重传,当接收方在收到一个失序的报文段后就立即发出重复确认,发送方只要一连收到三个重复确认就认为是网络阻塞,立即重传对方尚未收到的报文段,而不必继续等待设置的重传计时器时间到期。(提高网络吞吐量百分之20左右)

具体案例
image.png

3.4 快恢复算法

原理:快速恢复传输,和快重传搭配使用,当发生快重传时,进行”乘法减小“算法,此时不会再进行慢开始算法,而是执行快恢复算法,直接将cwnd设置为ssthresh减半后的值。

具体案例:cwnd为24时,收到三个重复确认,则进行快重传,此时执行”乘法减小“算法,ssthresh = cwnd/2,cwnd = ssthresh,直接便开始了拥塞避免算法。

注意:在TCP Reno版本采用快恢复算法时,慢开始算法只是在TCP连接建立时和网络出现超时时才使用,其他例如收到三个重复的确认,则会执行快恢复算法。
image.png

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

创新与乐趣的融合 —— 探索我们独家录音变音芯片在学舌玩具领域的应用

一&#xff1a;概述 学舌玩具&#xff0c;又称作复读玩具或模仿玩具&#xff0c;是一类设计用来录制人声并重复播放的互动式玩具。这类玩具以其能够模仿人类语音的特性而受到小朋友和宠物主人的喜爱。这些玩具通常具有以下特点和功能&#xff1a; 1. 录音和播放功能&#xff…

【C++航海王:追寻罗杰的编程之路】C++11(二)

目录 C11(上) 1 -> STL中的一些变化 2 -> 右值引用和移动语义 2.1 -> 左值引用和右值引用 2.2 -> 左值引用与右值引用比较 2.3 -> 右值引用使用场景与意义 2.4 -> 右值引用引用左值及其更深入的使用场景分析 2.5 -> 完美转发 C11(上) 1 -> STL…

4 -25

1 100个英语单词两篇六级阅读 2 cf补题&#xff1b; 3 仿b站项目看源码 debug分析业务。 上了一天课&#xff0c;晚上去健身。 物理备课&#xff0c;周六去上课腻。 五一回来毛泽东思想期末考试&#xff0c;概率论期中考试。

轻松搭建MySQL 8.0:Ubuntu上的完美指南

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 轻松搭建MySQL 8.0&#xff1a;Ubuntu上的完美指南 前言脚本编写脚本实现部署过程参数成功页面 彩蛋坏蛋解决方法 前言 在数字化时代&#xff0c;数据就像是我们的宝藏&#xff0c;而MySQL数据库就是…

【Qt 学习笔记】Qt常用控件 | 输入类控件 | Text Edit的使用及说明

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Qt常用控件 | 输入类控件 | Text Edit的使用及说明 文章编号&#xff…

【题解】牛客挑战赛 71 - A 和的期望

原题链接 https://ac.nowcoder.com/acm/problem/264714 思路分析 快速幂求逆元 费马小定理&#xff1a; a MOD − 1 ≡ 1 ( m o d M O D ) a^{\text{MOD}-1} \equiv 1 \pmod{MOD} aMOD−1≡1(modMOD)&#xff0c;可以转换为 a ⋅ a MOD − 2 ≡ 1 ( m o d M O D ) ① a \cd…

4.24总结

对部分代码进行了修改&#xff0c;将一些代码封装成方法&#xff0c;实现了头像功能&#xff0c;通过FileInputStream将本地的图片写入&#xff0c;再通过FileOutputStream拷贝到服务端的文件夹中&#xff0c;并将服务端的文件路径存入数据库中

Linear Blend Skinning (LBS)线性混合蒙皮

LBS是CG的基础概念之一。 Linear Blend Skinning: linearly blend the results of the vertex transformed rigidly with each bone. LBS&#xff1a;线性地混合顶点根据每个骨骼的刚性变形结果。 这个场景应用在哪里呢&#xff1f; 假如我们重建好一个人体&#xff0c;现在用…

水位监测识别摄像机

水位监测识别摄像机是一种利用人工智能技术进行水位监测的智能设备&#xff0c;其作用是监测水体的水位变化并识别潜在的水灾危险&#xff0c;以提供准确数据和及时预警&#xff0c;帮助保护人民生命财产安全。这种摄像机通过高清摄像头实时捕捉水体的图像&#xff0c;然后利用…

Coursera: An Introduction to American Law 学习笔记 Week 03: Property Law

An Introduction to American Law 本文是 https://www.coursera.org/programs/career-training-for-nevadans-k7yhc/learn/american-law 这门课的学习笔记。 文章目录 An Introduction to American LawInstructors Week 03: Property LawKey Property Law TermsSupplemental Re…

【yolo算法道路井盖检测】

yolo算法道路井盖检测 数据集和模型yolov8道路井盖-下水道井盖检测训练模型数据集pyqt界面yolov8道路井盖-下水道井盖检测训练模型数据集 算法原理 1. 数据集准备与增强 数据采集&#xff1a;使用行车记录仪或其他设备收集道路井盖的图像数据。数据标注&#xff1a;对收集到…

如何提交已暂存的更改到本地仓库?

文章目录 如何提交已暂存的更改到本地Git仓库&#xff1f;步骤1&#xff1a;确认并暂存更改步骤2&#xff1a;提交暂存的更改到本地仓库 如何提交已暂存的更改到本地Git仓库&#xff1f; 在Git版本控制系统中&#xff0c;当你对项目文件进行修改后&#xff0c;首先需要将这些更…

大学生在线考试|基于SprinBoot+vue的在线试题库系统系统(源码+数据库+文档)

大学生在线考试目录 基于SprinBootvue的在线试题库系统系统 一、前言 二、系统设计 三、系统功能设计 试卷管理 试题管理 考试管理 错题本 考试记录 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍&#…

valgrind,memcheck的使用

一&#xff0c;valgrind介绍 ​ valgrind是一个开源的&#xff0c;检测内存泄漏的工具&#xff0c;通常在linux下使用&#xff0c;除此之外&#xff0c;他还能检测内存管理错误&#xff0c;线程bug等错误。粗浅的来讲&#xff0c;valgrind由两部分构成&#xff0c;一部分用来模…

每日OJ题_BFS解决拓扑排序③_力扣LCR 114. 火星词典

目录 力扣LCR 114. 火星词典 解析代码 力扣LCR 114. 火星词典 LCR 114. 火星词典 难度 困难 现有一种使用英语字母的外星文语言&#xff0c;这门语言的字母顺序与英语顺序不同。 给定一个字符串列表 words &#xff0c;作为这门语言的词典&#xff0c;words 中的字符串已…

SpringBoot-无法从static上下文引用同非static方法

1.问题 说明&#xff1a;无法从static上下文引用同非static方法。 2.解决 说明&#xff1a;return后面的语句中&#xff0c;调用的是变量的方法&#xff0c;而不是类型的方法&#xff01;

Pytorch学习之路 - CNN

目录 理论预热 实践 构建卷积神经网络 卷积网络模块构建 实战&#xff1a;基于经典网络架构训练图像分类模型 数据预处理部分&#xff1a; 网络模块设置&#xff1a; 网络模型保存与测试 实践 制作好数据源&#xff1a; 图片 标签 展示下数据 加载models中提供的模…

CMake:相关概念与使用入门(一)

1、Cmake概述 Cmake是一个项目构建工具&#xff0c;并且是跨平台的。 关于项目构建我们所熟知的有Makefile&#xff0c;然后通过make命令进行项目的构建&#xff0c;并且大多数是IDE都继承了make&#xff0c;比如&#xff1a;VS的nmake&#xff0c;Linux下的GNU make、Qt的qma…

OpenCV与AI深度学习 | 如何使用YOLOv9分割图像中的对象

本文来源公众号“OpenCV与AI深度学习”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;如何使用YOLOv9分割图像中的对象 1 介绍 在我们之前的文章中&#xff0c;我们使用 YOLOv8 探索了令人兴奋的对象分割世界。分割使计算机视觉比…

Linux进程详解:进程优先级,调度算法,进程特性

文章目录 进程优先级Linux下的调度算法进程特性 进程优先级 进程要访问某种软硬件资源&#xff0c;此时进程需要通过一定的方式&#xff08;排队&#xff09;&#xff0c;来确认享受某种资源的先后顺序。 优先级是确认先后问题&#xff0c;权限是确认能不能的问题。 资源有限…
最新文章