【JavaEE初阶】网络原理—关于TCP协议值滑动窗口与流量控制,进来看看吧!!!
前言
🌟🌟本期讲解关于TCP协议的重要的机制“连接的建立和断开”~~~
🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客
🔥 你的点赞就是小编不断更新的最大动力
🎆那么废话不多说直接开整吧~~
TCP的协议特性分析,就像和每位大佬的交谈~~~~
目录
📚️1.滑动窗口
1.1概念的引出
1.2滑动窗口机制
1.3丢包问题
1.ack丢包
2.传输的数据丢包
1.4滑动窗口和确然应答的比较
📚️2.流量控制
2.1概念的引出
2.2流量控制机制
📚️3.拥塞控制
3.1概念的引出
3.2拥塞控制机制
📚️4.总结
📚️1.滑动窗口
1.1概念的引出
我们在之前了解到,关于TCP协议的传输的过程,由于每次传输后的确认应答机制,那么这就导致每次发送方,在发送数据后,收到ack那么才会进行下一次数据的传输。
问题:这就导致大量的时间浪费在等待接收ack的传输过程中了;
所以为了解决这个问题,即在保证可靠传输的前提下进行让效率尽量高一点;那么此时就引入了一个重要的概念“滑动窗口”;
1.2滑动窗口机制
我们之前是发送一个数据,然后等待ack,然后再发送一个数据,那么此时存在滑动窗口后,具体的机制就是如下:
所以此时,即一个“批量传输”的过程,即在发送一个数据后,那么此时就不会进行等待接收ack,那么就直接继续发送数据,然后等连续发送了几条数据后,再进行统一的等待过程;
问题1:那么此时的所谓的“滑动窗口”的滑动的描述是从何而来的呢?
且看如下的图:
那么此时可以将上述的1~1000,1001~2000,2001~3000....来进行形象的描述成上述的过程,那么此时就可发现,此时的白色部分就像“一个窗口”;
问题2:这里的滑动是如何进行提现的呢?
这里就涉及到什么时候进行下一个数据的传输了,这里不是等所有的对应ack返回后在进行下一批的数据的发送,而是等待一个ack收到后,就直接进行滑动一个空格,那么此时就是有滑动的效果了~~
所以机制总结如下:
1.窗口大小就是无需等待ack的接受的最大数据量的发送(其实就是批量传输的最大值,白色部分方框里面)
2.发送前四个阶段的数据的时候,不用等待接收ack(这里的四个即表示的窗口的大小哦)
3.当每次收到一个ack时,那么窗口就向后面移动一个空格,以此类推(这里的空格就是数据哦)
4.操作系统内核为了维护这个滑动窗⼝, 需要开辟 发送缓冲区 来记录当前还有哪些数据没有应答;( 只有确认应答过的数据, 才能从缓冲区删掉)
5.窗口越大,那么对应的网络吞吐量就会变大;
1.3丢包问题
1.ack丢包
具体的情况就是如下图所示:
问题3:此时可以看到,图中有几个ack的放回是发生了一定的丢包的问题,那么此时我们该如何进行解决的呢?
解决办法:
不用做任何的操作,为啥不用做任何的操作;注意这里涉及到一个重要的概念,即确认序号;
当第一个确认序号为1001的ack丢了之后,那么可以看到下一个2001的ack没有发生丢包,那么就已经表示,在收到2001的ack收到之后,就表示上一个数据1~1001已经传输到主机B了那么此时,就算1001的ack丢包了,也没有太大的关系~~~
ack丢包总结:就算ack在回传的过程中存在丢包的问题,那么只要存在一个ack放回成功,就表示前面的数据已经安全的发送到位了~~
2.传输的数据丢包
具体的情况是如下所示的:
问题4:可以看到上述的过程中是存在一个问题的,当数据丢包后是如何进行解决的?
解决:
具体方法在上述的展示中也进行了一定的理解,下面由小编为大家讲解一下具体的过程吧~
在发生1001~2000的数据丢包后,就会发现此时就会一直进行1001的ack确认报文的发送,知道发送方意识到1001~2000丢包了,那么就会进行重传~~
注意:
在接收到丢包的数据之后,如果没有其他的数据丢包,那么就直接发送7001,表示在7001确认序号之前的数据我们都收到了,不用再次从2001的ack进行传输了;那么如果在这个丢包的数据之后还丢包了,那么就会继续发送丢包是数据的首个序号,重复上述解决过程
总结:
在上述的重传的中,这个过程的效率是非常高的,这里的重传做到了针对性,已经收到了的数据,不必重新发送,那么这种重传就是“快速重传”
1.4滑动窗口和确然应答的比较
滑动窗口中也是包含有确认应答的机制,只不过是转成批量的了,批量的前提就是一段时间发送数据很多,如果发送的数据少,那么就会退化成确认应答的机制了
判断可靠性:
如果是滑动窗口:那么就是在丢包的时候,快速重传保证可靠性,连续有多个ack进行数据的索取,那么此时就能进行数据的重传;如果是确认应答: 如果在丢包的时候,确认应答保证可靠性,达到超时时间后,没收到ack,那么就会进行重传
📚️2.流量控制
2.1概念的引出
我们在上面的描述中了解到了,关于滑动窗口这个概念,这个的窗口越大,更多的数据同时用一块时间等待,提高了效率;
问题5:但是这里的问题就是,窗口大小能无限大吗?
答案是当然不能,因为这里的在提高效率的前提就是保证可靠性,如果接收方的接收缓冲区满了,那么就会造成再次发送数据时,就会发生丢包的后果,这种后果就是重传也没有用了~~
那么此时为了控制发送的速度,就引入了“流量控制”的概念
2.2流量控制机制
此时就涉及到TCP协议报文其中一个字段:即“16位窗口大小”,这里的不为64k,在TCP报头中还涉及到一个参数,即“窗口扩展因子”,那么此时,真正的窗口大小就是16*2^窗口扩展因子;
注意:这个字段是用来反馈给发送方,表示下次发送的窗口的大小
注意:这个字段是在ack的发送的报文中存在才有意义,在普通报文中进行发送,这个是没有意义的;
这里的窗口大小,是根据接收方的接收缓冲区的剩余的空间大小,来设定ack中窗口大小的数值,然后这里发送方会根据这个数值来设置自己的窗口大小;
具体的图示是如下的:
解释:
如上,当这里的窗口大小为0的时候,可以发现发送方会停止发送,然后发送方会尝试周期性的发送“窗口探测包” (这里的窗口探测包是不携带载荷的,对于业务时是没有影响的,主要的目的是为了触发ack的确认应答报文的发送,来确定这里的ack报文中的窗口大小是多少);那么当这里的缓冲区(窗口)大小不为0的时候,发送方又会继续的发送数据;
📚️3.拥塞控制
3.1概念的引出
在上面我们讲解到了流量控制这个概念,那么我就知道了,这是针对接收方的角度来进行约束发送方的发送速度,而这里谈到的拥塞控制描述的是关于网络环境来影响发送方的发送速率;
我们知道网络环境是非常复杂的,如果存在一处地方发生了堵塞的情况,那么就会导致,接收方接收的速度再快也没有用,发送方发送速度再快也没有用;
所以就有以下方案:
如果按照某个窗口的大小进行发送数据,发生了丢包,那么就表示这个网络环境存在堵塞的情况,那么就会减小窗口的大小,如果没有出现丢包的情况,那么就增大窗口的大小~~~
所以总结:
上述的方法简化了问题,适应了复杂多变的网络情况,在中间节点的位置,什么时候拥堵,什么时候不拥堵,那么按照上述的描述,就可以让发送的速率动态的变化;
如此以上,那么就叫做“拥塞控制”
3.2拥塞控制机制
我们知道网络环境是非常复杂的,那么对于拥塞控制的标准就是要靠实验来进行的;
具体的步骤:
1.慢启动:
刚开时的时候,传输数据的窗口是非常小的,因为保守起见
2.指数增长:
如果上述的条件没有发生丢包,那么就会增大窗口的大小,此时的增长速率就是按照指数来进行增长的
3.线性增长:
由于指数增长非常快,为了保证网络不会发生阻塞拥堵的情况,那么当达到一定的阈值后,就会线性增长
4.重回再增长:
由于线性增长的持续存在,那么到达一定的时间后,还是会发生网络堵塞引起丢包问题,那么一旦发生丢包问题,那么就会将拥塞窗口设置成一个较低的值,那么此时又会重新开始
那么上述的具体过程就是如下图所示:
解释:
此时我们看到当出现丢包的问题时:
第一:ack快速重传(滑动窗口中的概念),然后提醒说明此处发生了丢包的问题;
第二:在方法一过后直接将拥塞窗口降到最低,然后重新设定阈值;(经典版本)
第三:在方法一过后直接将拥塞窗口降到一个新的阈值,不是最低点;(这是新的版本没有慢启动和指数增长了,传输的效率大大增加)
那么以上就是关于拥塞控制的小编了解的全部知识了~~~
📚️4.总结
💬💬本期小编主要讲解了关于TCP协议中比较重要的特性,即滑动窗口,流量控制,以及拥塞控制,当然这里每一节涉及到的丢包的问题,和控制发送方的发送窗口对应的两种控制的机制需要大家好好的理解理解~~~
🌅🌅🌅~~~~最后希望与诸君共勉,共同进步!!!
💪💪💪以上就是本期内容了, 感兴趣的话,就关注小编吧。
😊😊 期待你的关注~~~
相关文章:

【JavaEE初阶】网络原理—关于TCP协议值滑动窗口与流量控制,进来看看吧!!!
前言 🌟🌟本期讲解关于TCP协议的重要的机制“连接的建立和断开”~~~ 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 🔥 你的点赞就是小编不断更新的最大动力 …...

无人机避障——使用三维PCD点云生成的2D栅格地图PGM做路径规划
着重介绍通过对三维 PCD 点云进行处理生成 2D 栅格地图 PGM,而后将该 PGM 地图充分运用到无人系统路径规划之中,使得无人机能够依据此规划合理避开飞行路线上可能出现的障碍物。(解决如何使用PGM的问题) Hybrid A*算法 参考博客…...
supermall项目上拉加载bug分析
1.bug分析 bug出现的过程是这样的:better-scroll框架会计算滚动内容的高度(通过BScroll对象的scrollerHeight属性记录滚动内容的高度) 由于内容中的图片资源还未加载成功 就已经完成计算 导致计算结果错误 而计算之后 图片资源随之加载完成 这时候better-scroll框架…...

【linux网络编程】| socket套接字 | 实现UDP协议聊天室
前言:本节内容将带友友们实现一个UDP协议的聊天室。 主要原理是客户端发送数据给服务端。 服务端将数据再转发给所有链接服务端的客户端。 所以, 我们主要就是要实现客户端以及服务端的逻辑代码。 那么, 接下来开始我们的学习吧。 ps:本节内容…...

第二届开放原子大赛-开源工业软件算法集成大赛即将启动!
第二届开放原子大赛-开源工业软件算法集成大赛作为开放原子开源基金会组织举办的开源技术领域专业赛事,聚焦开源底座框架平台建设,通过组件化集成的开发模式,丰富平台功能模块,拓展其应用场景,以此促进工业软件生态的繁…...
PXC集群(Percona XtraDB Cluster )
一、简介 基于Galera Cluster技术的开源分布式数据库解决方案,它允许你在多个MySQL服务器之间创建一个同步的多主复制集群。 特点: * 多主复制架构: PXC集群支持多主复制,每个节点都可以同时读写数据,这使得应用程序可以更灵活地进行负载均衡和高可用性设置。* 同步复制:…...

分布式光伏是什么意思?如何高效管理?
分布式光伏系统是指在用户现场或靠近用电现场配置较小的光伏发电供电系统,以满足特定用户的需求。根据通知,分布式光伏系统主要有以下几类定义: 10kV以下电压等级接入,且单个并网点总装机容量不超过6MW的分布式电源:这…...
提问GPT
1 理解GPT AI模型即采用深度学习技术的人工神经网络。 你不会被AI取代,而是会被熟练运用AI的人取代 1.1 问答或对话是普通用户与这一轮新AI产品的典型交互方式。 GPT生成式预训练转换器 了解当前GPT产品的形式: 通用聊天机器人…...

李飞飞团队新突破:低成本高泛化机器人训练法,零样本迁移成功率90%!
在机器人训练中,如何高效地利用模拟环境一直是研究者们关注的重点问题。 近日,美国斯坦福大学李飞飞教授团队提出了一种突破性的“数字表亲”(digital cousins)概念。这一创新方法既保留了数字孪生的优势,又大大降低了…...
PHP内存马:不死马
内存马概念 内存马是无文件攻击的一种常用手段,利用中间件的进程执行某些恶意代码。首先要讲的是PHP不死马,实质上就是直接用代码弄一个死循环,强占一个 PHP 进程,并不间断的写一个PHP shell,或者执行一段代码。 不死…...

【python】OpenCV—Connected Components
文章目录 1、任务描述2、代码实现3、完整代码4、结果展示5、涉及到的库函数6、参考 1、任务描述 基于 python opencv 的连通分量标记和分析函数,分割车牌中的数字、号码、分隔符 cv2.connectedComponentscv2.connectedComponentsWithStatscv2.connectedComponents…...

【优选算法篇】前缀之序,后缀之章:于数列深处邂逅算法的光与影
文章目录 C 前缀和详解:基础题解与思维分析前言第一章:前缀和基础应用1.1 一维前缀和模板题解法(前缀和)图解分析C代码实现易错点提示代码解读题目解析总结 1.2 二维前缀和模板题解法(二维前缀和)图解分析C…...
win10 更新npm 和 node
win10 更新npm 和 node win10 更新 npm winR 输入cmd,打开命令行,并输入如下 # 查看当前npm版本 npm -v # 清缓存 npm cache clean --force # 强制更新npm,试过npm update -g,没起作用,版本没变化 npm install -g …...

搜索引擎算法更新对网站优化的影响与应对策略
内容概要 随着互联网的不断发展,搜索引擎算法也在不断地进行更新和优化。了解这些算法更新的背景与意义,对于网站管理者和优化人员而言,具有重要的指导意义。不仅因为算法更新可能影响到网站的排名,还因为这些变化也可能为网站带…...

使用 Q3D 计算芯片引线的 AC 和 DC R 和 L
摘要: 模具经常用于电子行业。了解其导联的寄生特性对于设计人员来说很重要。Q3D 是计算 RLCG 的完美工具。它可用于高速板或低频电力电子设备。 在下面的视频中,我们展示了如何修改几何结构、设置模型和检查结果。 详细信息: 几何图形可以在 Q3D 中创建,也可以作为不同…...
前端_008_Vite
文章目录 Vite项目结构依赖构建插件 官网:https://vitejs.cn/vite3-cn/guide/ 一句话简介:前端的一个构建工具 Vite项目结构 index.html package.json vite.config.js public目录 src目录 #新建一个vite项目 npm create vitelatest原有项目引入vite需要…...

ssm007亚盛汽车配件销售业绩管理统(论文+源码)_kaic
本科毕业设计论文 题目:亚盛汽车配件销售业绩管理系统设计与实现 系 别: XX系(全称) 专 业: 软件工程 班 级: 软件工程15201 学生姓名: 学生学号: 指导教师&am…...
如何使用python完成时间序列的数据分析?
引言 时间序列分析是统计学和数据分析中的一个重要领域,广泛应用于经济学、金融、气象学、工程等多个领域。 时间序列数据是按时间顺序排列的一系列数据点,通常用于分析数据随时间的变化趋势。 本文将介绍时间序列分析的基本概念、常用方法以及如何使用Python进行时间序列…...
数字ic设计,Windows/Linux系统,其他相关领域,软件安装包(matlab、vivado、modelsim。。。)
目录 一、总述 二、软件列表 1、modelsim_10.6c 2、notepad 3、matlab 4、Visio-Pro-2016 5、Vivado2018 6、VMware15 7、EndNote X9.3.1 8、Quartus 9、pycharm 10、CentOS7-64bit 一、总述 过往发了很多数字ic设计领域相关的内容,反响也很好。 最近…...

SD-WAN分布式组网:构建高效、灵活的企业网络架构
随着企业数字化转型的深入,分布式组网逐渐成为企业网络架构中的核心需求。无论是跨区域的分支机构互联,还是企业与云服务的连接,如何在不同区域实现高效、低延迟的网络传输,已成为业务成功的关键。SD-WAN(软件定义广域…...

AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南
点一下关注吧!!!非常感谢!!持续更新!!! 🚀 AI篇持续更新中!(长期更新) 目前2025年06月05日更新到: AI炼丹日志-28 - Aud…...

XCTF-web-easyupload
试了试php,php7,pht,phtml等,都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接,得到flag...
MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例
一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...
【C语言练习】080. 使用C语言实现简单的数据库操作
080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...

JUC笔记(上)-复习 涉及死锁 volatile synchronized CAS 原子操作
一、上下文切换 即使单核CPU也可以进行多线程执行代码,CPU会给每个线程分配CPU时间片来实现这个机制。时间片非常短,所以CPU会不断地切换线程执行,从而让我们感觉多个线程是同时执行的。时间片一般是十几毫秒(ms)。通过时间片分配算法执行。…...
PAN/FPN
import torch import torch.nn as nn import torch.nn.functional as F import mathclass LowResQueryHighResKVAttention(nn.Module):"""方案 1: 低分辨率特征 (Query) 查询高分辨率特征 (Key, Value).输出分辨率与低分辨率输入相同。"""def __…...

Python Ovito统计金刚石结构数量
大家好,我是小马老师。 本文介绍python ovito方法统计金刚石结构的方法。 Ovito Identify diamond structure命令可以识别和统计金刚石结构,但是无法直接输出结构的变化情况。 本文使用python调用ovito包的方法,可以持续统计各步的金刚石结构,具体代码如下: from ovito…...

搭建DNS域名解析服务器(正向解析资源文件)
正向解析资源文件 1)准备工作 服务端及客户端都关闭安全软件 [rootlocalhost ~]# systemctl stop firewalld [rootlocalhost ~]# setenforce 0 2)服务端安装软件:bind 1.配置yum源 [rootlocalhost ~]# cat /etc/yum.repos.d/base.repo [Base…...
Go语言多线程问题
打印零与奇偶数(leetcode 1116) 方法1:使用互斥锁和条件变量 package mainimport ("fmt""sync" )type ZeroEvenOdd struct {n intzeroMutex sync.MutexevenMutex sync.MutexoddMutex sync.Mutexcurrent int…...
第7篇:中间件全链路监控与 SQL 性能分析实践
7.1 章节导读 在构建数据库中间件的过程中,可观测性 和 性能分析 是保障系统稳定性与可维护性的核心能力。 特别是在复杂分布式场景中,必须做到: 🔍 追踪每一条 SQL 的生命周期(从入口到数据库执行)&#…...