【Linux从青铜到王者】tcp协议2

news2025/1/16 8:56:20

滑动窗口

滑动窗口是什么

上篇提到如果两端发送数据如果是一发一收那就是串行,效率很低,所以可以一次发送多个报文,一次也可以接受多个报文,可以大大的提高性能(其实是将多个段的等待时间重叠在一起了)

那么是怎么发送多个报文的呢?靠的就是滑动窗口这个大杀器

滑动窗口是什么?是为了让tcp并发地发送大量暂时不需要ACK的数据段,从而提高发送效率的解决方案(这里也涉及流量控制的解决方案,和重传机制也有关系!)

如果学习过双指针算法的同学可能听到滑动窗口这个名字很熟悉,其实这里就是类似的

之前我们说过可以把缓冲区当做一个单位大小为char的数组,然后有两个指针win_start和win_end分别指向滑动窗口的起始位置和结束位置

这样发送缓冲区就被分成了三个区域:

          滑动窗口的左边区域,处于滑动窗口的区域,滑动窗口的右边区域

分别对应已发送已确认可以直接发送但是尚未确认未发送或者没数据的区域

下图为示范例子:

  • 窗口大小就是指无需等待确认应答而可以继续发送数据的最大值。图中,窗口大小为4个段,也就是4000个字节。
  • 发送前四个段的时候, 不需要等待任何ACK, 直接发送。
  • 收到第一个ACK后, 滑动窗口向后移动, 继续发送第五个段的数据; 依次类推。
  • 操作系统内核为了维护这个滑动窗口, 需要开辟 发送缓冲区 来记录当前还有哪些数据没有应答; 只有确认应答过的数据, 才能从缓冲区删掉——所以一个数据被发送后,不能立马被移除
  • 窗口越大, 则网络的吞吐率就越高

滑动窗口在哪里?

滑动窗口本质上就是发送缓冲区的一个区域

滑动窗口怎么理解?

【win_start,win_end】:滑动窗口!!——本质就是两个数组下标充当指针作用

win_start=确认序号

win_end=win_start(确认序号)+win(接收方的接受能力)——16位窗口大小

所谓的窗口滑动,本质就是下标移动

因为滑动窗口发送的是可以直接发送尚未确认的数据,所以要考虑对方的接受能力,所以滑动窗口的大小由对方的接受能力决定!!!(后续会有变化)

那么最开始的时候,我还没发送数据的时候,滑动窗口的大小是多大?

所以在三次握手的时候,滑动窗口的大小,双方已经协商完毕

滑动窗口的变化以及流量控制

滑动窗口可以往左移动吗?

不可以,win_start=确认序号,而确认序号=序号 +1的,所以滑动窗口只可能往左移动

滑动窗口的大小不变吗?变大?变小?为0?

当确认一个报文后又发送一个报文的时候,滑动窗口的大小就是不变的

当一次发了四五个报文,只有前面两个应答了,那么win_start+=2个报文的长度,滑动窗口也就变小了。后面全部报文都应答了,win_end+=三个报文的长度,滑动窗口也就变大了

所以不变,变大和变小都是可以的——流量控制!!!

接收方能力弱:我就发慢点

接收方能力强:我就发快点

变大变小不变都行,这才叫控制

如果滑动出去,越界了怎么办?把发送缓冲区想象成环形结构即可!!!(环形数组可以用数组来模拟实现)

这里也体现到上篇提到的如果报文发送了,还没应答,就不能丢弃,暂时存起来,存在哪?滑动窗口里

报文丢失

一次发多个数据,那么肯定会有上篇讲的丢失报文的问题,那么报文丢了怎么办?

我们可以将报文丢失分为三类:最左侧丢失,中间丢失,右侧丢失

如果发了序号2000,3000,4000,5000的四个报文,正常情况下发送方应该收到确认序号为2001,3001,4001,5001的ACK

最左侧丢失就是2001ACK没收到,那么此时后面的确认序号就不再是3001,4001,5001了,而是1001,因为确认序号的定义是该序号之前的数据,全部收到

所以连续接收到三个1001ACK,但是明明发的是2000,3000,4000,5000,所以就可以推测出是2000报文丢失了,所以会补发2000报文!!!

如果是中间丢失,也就是3001丢失,那么发送方是接收到2001ACK的,所以窗口会向右移动一个长度,此时中间丢失就变成最左边丢失,重复以上动作即可

如果是最右侧丢失,那么结果还是一样的,窗口不断右移直到丢失的报文成为最左侧,变成最左侧丢失的情况,然后重复上述操作!

总结:不管是什么丢失,最后都会变成最左侧丢失

这里涉及到一个重传机制

快重传:如果连续收到三个同样的确认序号的时候,会立即将对应的报文进行补发!!!

有人会想了,都有快重传了,听名字就挺快的,还要超时重传干什么?

细看的话会发现快重传是有条件的,要连续收到三个同样的确认序号,不是连续的话只能超时重传了

所以超时重传是兜底的,快重传是提高效率的重传策略,两者互相配合

在滑动窗口这里,可以充分体会到确认序号的的价值!!!

还有将缓冲区视为字节环形结构的作用——有了序号和确认序号,保证了可靠性——发送成功或者失败都100%知道!!!

到这里不得不赞叹tcp的设计,几个字段互相配合不仅仅保证了可靠性,还实现了效率的提升

拥塞控制

到目前为止我们讲的都是两个主机之间的,两个主机之间通信还要经过网络这一环节

假设有一天网络突然瘫痪(网络非常繁忙)了,发送的报文迟迟未被接收,那么此时要进行超时重传吗?

如果这时进行超时重传,注意此时不再是两台主机之间通信,可能有很多台主机都向你超时重传发送信息,注意此时网络已经瘫痪,超时重传等于再发一次信息,无异于压死骆驼的最后一根稻草,让网络雪上加霜

所以此时不能进行网络重传

当出现小面积丢包的时候,认为是丢包,进行超时重传

当出现大面积丢包的时候,认为是网络出现问题,不超时重传,而是拥塞控制

什么是拥塞控制呢?就是先试探,慢慢发,随着你应答的次数增多而显著提高发送的数据量

滑动窗口决定了我们单次发送数据量的多少——所以滑动窗口的大小不仅与对方的接受能力有关,还要考虑网络的状态

滑动窗口=min(拥塞窗口大小,对方的窗口大小)

拥塞窗口本质就是一个数字,当发送数据量超过拥塞窗口的时候,有很大的概率会引起网络拥塞

拥塞窗口=2^n,就是个指数函数。可以发现该函数完美切合要求,慢启动,快增长。

前期慢,增长快——前期慢是为了试探网络环境如何,增长快是为了尽快进行正常网络的通信

当拥塞窗口的值超过阈值的时候,拥塞窗口就会变成线性增长,变化规律如图所示,就不赘述

我们发送数据的时候,就是按照图片的规律来发送吗?当然不是,发送数据靠什么?靠滑动窗口?滑动窗口win_start=ack,win_end=min(拥塞窗口大小,对方窗口大小)

所以可能发送到一半就按照对方窗口的大小发送了

但是拥塞窗口必须一直在变化,因为网络的状态要一直探测

tcp的保活机制(心跳机制)

机器掉电,网线断开的时候,tcp内部有一个计时器,当超过固定时间后仍未应答则自动关闭连接,但是tcp的时间定的太长了,一般更推荐在应用层完成

listen的第二个参数

全连接队列

饭店排队场景类似

如果一个饭店里很多人用餐没有位置了,此时又新来了客人,你直接对客人说走吧没位置了,那肯定会被老板喷个狗血淋头,因为等里面的客人吃完了,如果此时又没新的客人来,高峰期的时候一些座位就会被闲置了

如果你在外面放了一些椅子,让客人在外面等,这时里面的人用完餐了,外面的人就可以直接进去用餐了,高峰期里面的位置被闲置的概率大大降低

但是你也不能在外面摆太长,比如摆个几百张,除了前面几十张等得起,后面的人要等的时间太久了,而且椅子也是占空间的,外面的地可不是都是你们店的

上面的饭店就类似应用层,客人就是连接,外面摆的椅子就是全连接队列,全连接队列不能太长

相关问题

connect参与三次握手吗?

connect参与三次握手,发送SYN请求后,双方操作系统自动完成

accept参与三次握手吗?

当一个服务器通过bind函数开始监听该套接字上的连接请求,一旦有客户端尝试建立连接,三次握手成功后,服务器端的accept调用才会返回,从全连接队列中获得一个新的套接字

所以是不参与的,是发生在三次握手之后的

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

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

相关文章

Golang | Leetcode Golang题解之第300题最长递增子序列

题目&#xff1a; 题解&#xff1a; func lengthOfLIS(nums []int) int {if len(nums)<1{return len(nums)}dp : make([]int,len(nums))for i:0;i<len(nums);i{dp[i]1}res : 1for i:1;i<len(nums);i{for j:0;j<i;j{if nums[i] > nums[j]{dp[i] max(dp[i],dp[j…

Java 沙漏图案(Hour-glass Pattern)

给定正整数 n&#xff0c;以沙漏形式打印数字模式。示例&#xff1a; 输入&#xff1a;rows_no 7 输出&#xff1a; 1 2 3 4 5 6 7 2 3 4 5 6 7 3 4 5 6 7 4 5 6 7 5 6 7 6 7 7 6 7 5 6 7 4 5 6 7 3 4 5 6 7 2 3 4 5 6 7 1 2 3 4 5 6…

物联网平台简介与选型

前言 什么是物联网&#xff1f; 简单解释&#xff1a;把你感兴趣的事物连接到网络。 阿里云定义&#xff1a;物联网&#xff08;Internet of Things&#xff0c;简称 IoT&#xff09;是指通过互联网连接和通信的物理设备和对象的网络。它是一个由传感器、软件和通信设备组成的…

Attribute Manipulation(属性编辑)、disentanglement(解纠缠)常用的两种做法:线性探针和PCA

解纠缠也对应于属性编辑&#xff0c;比如人脸的属性编辑&#xff0c;将人脸变微笑、变衰老&#xff0c;其中每一个属性变化也对应了一种有意义的latent direction 。想要应用这种direction可以分为两种方式&#xff1a;有监督的linear-probe&#xff08;线性探针&#xff09;和…

Logback 日志打印导致程序崩溃的实战分析

在软件开发和运维中&#xff0c;日志记录是必不可少的一环&#xff0c;帮我们追踪程序的行为&#xff0c;定位问题所在。然而&#xff0c;有时日志本身却可能成为问题的根源。本文将通过一个真实的案例来探讨 Logback 日志系统中的一个常见问题&#xff0c;当并发量大&#xff…

Vue.js常见指令

一、v-text与v-html v-text更新html元素的innerText v-html更新html元素的innerHtml 如果需要更新部分内容需要使用{{ }} 双括号差值表达式 案例&#xff1a; <!DOCTYPE html> <html><head><meta charset"utf-8"><title>VUE指令 …

python pip 错误 ModuleNotFoundError: No module named pip._internal 解决办法

问题 升级新版pip 之后,不论是本地,还是使用anaconda环境,都有可能在用pip下载的时候出现错误: ModuleNotFoundError: No module named pip._internal&#xff0c;我的电脑中存在好几个版本的Python。 解决办法&#xff1a; python -m ensurepip python -m pip install --upgr…

图片及色彩编码

1、日期类 ###年份 date_format(KaTeX parse error: Expected EOF, got # at position 14: 批售月份, %Y年) #̲##季度 (CASE WHEN…批售月份, ‘%m’) IN (1,2,3) THEN ‘1季度’ WHEN date_format( 批售月份 , ′ W H E N d a t e f o r m a t ( 批售月份, %m) IN (4,5,6) TH…

【鸿蒙踩坑记录】解决:tabs滑动时,第一个和最后一个页签回弹大问题

一、背景 tabs滑动切换时&#xff0c;第一个页签右滑回弹大&#xff0c;最后一个页签左滑回弹大&#xff0c;如何关闭回弹效果 二、问题展现 图1:第一个页签右滑时回弹较大 图2:最后一个页签左滑时回弹较大 预期&#xff1a;关闭回弹效果 三、实现思路 给第一个和最后一个…

项目负责人的高效会议策略:从准备到追踪

项目负责人的高效会议策略&#xff1a;从准备到追踪 前言一、会议低效的常见陷阱二、高效会议的准备策略三、会议实施的技巧四、会议追踪的重要性结语 前言 在项目管理的世界里&#xff0c;时间就是金钱&#xff0c;效率就是生命。作为项目负责人&#xff0c;我深刻体会到了会议…

Java网络编程----UDP实现单播,组播,广播

文章开头&#xff0c;先来回忆一下 什么是UDP&#xff1f; UDP 的全称是 User Datagram Protocol&#xff0c;用户数据报协议。它不需要所谓的握手操作&#xff0c;从而加快了通信速度&#xff0c;允许网络上的其他主机在接收方同意通信之前进行数据传输。 UDP 的特点主要有…

Python 教程(七):match...case 模式匹配

目录 专栏列表前言基本语法match 语句case 语句 模式匹配的类型示例具体值匹配类型匹配序列匹配星号表达式命名变量复杂匹配 模式匹配的优势总结 专栏列表 Python教程&#xff08;一&#xff09;&#xff1a;环境搭建及PyCharm安装Python 教程&#xff08;二&#xff09;&…

智能环保气膜网球馆:大空间与防雾霾的完美结合—轻空间

在现代都市生活中&#xff0c;空气质量和空间限制成为许多体育设施的挑战。气膜技术的出现&#xff0c;为这些问题提供了卓越的解决方案。我们的智能环保气膜网球馆&#xff0c;不仅拥有宽敞的空间&#xff0c;还具备卓越的防雾霾功能&#xff0c;为体育爱好者提供了一个理想的…

牧野电火花机床联网

一、找到可选项 选择主面板中的【可选项】按钮&#xff0c;弹出来的对话框如下图所示。 二、属性设定 在左下角部分找到【属性设定】&#xff0c;如序号一所示&#xff0c;在弹出的属性设定对话框中选中【牧野EDM服务器】&#xff0c;如下图所示。 三、选则MES模式 按照上图…

苹果推送iOS 18.1带来Apple Intelligence预览

&#x1f989; AI新闻 &#x1f680; 苹果推送iOS 18.1带来Apple Intelligence预览 摘要&#xff1a;苹果向iPhone和iPad用户推送iOS 18.1和iPadOS 18.1开发者预览版Beta更新&#xff0c;带来“Apple Intelligence”预览。目前仅支持M1芯片或更高版本的设备。Apple Intellige…

Electron学习笔记(一)基础环境

目录 前言 基础环境准备 安装 Node.js 配置项目文件 通过代理服务安装 通过国内仓库安装 一些常见问题&#xff1a; 前言 一个新手学习Electron的笔记&#xff0c;记录为主&#xff0c;仅供参考。 其他文章见专栏目录。 基础环境准备 开发之前先将基础环境搭建好。 …

灯具外贸公司用什么企业邮箱好

灯具外贸公司面对海外市场的推广、产品销售、客户沟通、市场信息收集等多重需求&#xff0c;选择一个合适的企业邮箱显得尤为重要。本文将介绍灯具外贸公司为什么应选择Zoho Mail企业邮箱&#xff0c;并详细探讨其优势和功能。 一、公司背景 广东省深圳市光明新区&#xff0c…

创建 Llama-3.1-70B-Japanese-Instruct-2407 的 Ollama 模型

创建 Llama-3.1-70B-Japanese-Instruct-2407 的 Ollama 模型 1. 下载 gguf 文件2. 创建 Modelfile3. 创建 Ollama 模型4. 运行 Ollama 模型5. &#xff08;可选&#xff09;其他 Modelfile 1. 下载 gguf 文件 使用浏览器打开 https://huggingface.co/mmnga/Llama-3.1-70B-Japa…

DELL服务器RAID配置详细教程

DELL服务器RAID配置教程 在启动电脑的时候按CTRLR 进入 RAID 设置见面如下图 名称解释&#xff1a; Disk Group&#xff1a;磁盘组&#xff0c;这里相当于是阵列&#xff0c;例如配置了一个RAID5&#xff0c;就是一个磁盘组 VD(Virtual Disk)&#xff1a; 虚拟磁盘&#xff…