计算机网络微课堂(湖科大教书匠)TCP部分

news2024/9/20 18:36:49

计算机网络微课堂(湖科大教书匠)TCP部分

【计算机网络微课堂(有字幕无背景音乐版)】

TCP的流量控制

一般来说,我们希望数据传输得更快一些。但如果发送方把数据发送得过快,接收方就可能来不及接收,这就会造成数据的丢失。

流量控制(flow control)就是让发送方的发送速率不要太快,要让接收方来得及接收,利用滑动窗口机制可以很方便地在TCP连接上实现对发送方的流量控制。

在这里插入图片描述

如果主机B接收窗口被调整为0,那么主机A就会启动持续计时器,持续计时器超时,就发送零窗口探测报文(携带1字节数据)。然后主机B要对零窗口探测报文进行确认,并告知自己的接受窗口。

主机B即使接收窗口为0,也必须接受零窗口探测报文段、确认报文段、以及携带有紧急数据的报文段。

零窗口探测报文段也有重传计时器,如果零窗口探测报文段丢失,那么等到重传计时器超时后,零窗口探测报文段会被重传。

在这里插入图片描述

TCP的拥塞控制

在这里插入图片描述

拥塞控制有四种算法:慢开始,拥塞避免,快重传,快恢复。

cwnd:拥塞窗口(动态变化)

cwnd维护原则:没有出现拥塞,cwnd就增大;出现拥塞,cwnd就减少。

拥塞窗口值是几就能发送几个数据报文段。

发送方将cwnd作为发送窗口swnd,cwnd=swnd。

慢开始门限ssthresh:

当 cwnd < ssthreshde 的时候,使用慢开始算法;

当 cwnd > ssthreshde 的时候,使用拥塞控制算法;

当 cwnd = ssthreshde 的时候,可以使用慢开始算法,也可以使用拥塞控制算法;

在这里插入图片描述

慢开始和拥塞避免

**慢开始:**每个传输轮次,发送方每收到一个对新报文段的确认时,就把拥塞窗口值+1。

比如最开始cwnd=1;发送一个,收到一个,cwnd+1=2;第二轮发送两个,收到两个,cwnd+2=4;第三轮发送4个,收到4个,cwnd+4=8。

也就是说,慢开始算法中cwnd值以指数规律增大。

当拥塞窗口值增长到慢开始门限时,就开始拥塞避免算法。

拥塞避免:每个传输轮次后,cwnd值只能线性+1.

在这里插入图片描述

传输图中丢失数据包,出现重传计时器超时的情况,判断网络很可能出现拥塞控制:

将ssthresh值更新为发生拥堵时cwnd值的一半;

将cwnd值减少为1,并重新开始执行慢开始算法。

比如图中的cwnd=24,ssthresh就设置为12.

在这里插入图片描述

全部过程如图所示:

在这里插入图片描述

“慢开始”是指一开始向网络注入的报文段少,并不是指拥塞窗口cwnd增长速度慢;
“拥塞避免”并非指完全能够避免拥塞,而是指在拥塞避免阶段将拥塞窗口控制为按线性规律增长,使网络比较不容易出现拥塞;

快重传

在这里插入图片描述

发送M1报文段,接收方立即确认M1,

发送M2报文段,接收方立即确认M2;

发送M3报文段,丢失,接收方无法回复;

发送M4报文段,接收方重复确认M2;

发送M5报文段,接收方重复确认M2;

发送M6报文段,接收方重复确认M2;

发送方立即重传M3报文段,接收方重复确认M2;

在这里插入图片描述

快恢复

发送方将慢开始门限ssthresh值和拥塞窗口cwnd值调整为当前窗口的一半;开始执行拥塞避免算法。

在这里插入图片描述

TCP超时重传时间的选择

如果将报文段超时重传的时间,设置得比往返时间RTT的值小,就会引起不必要的重传加重网络负荷。

在这里插入图片描述

如果将超时重传的值设置的远大于RTT的值,会导致网络的空闲时间增大,降低了传输效率。

在这里插入图片描述

超时重传时间RTO应略大于往返时间RTT。

在这里插入图片描述

但是由于下面层次的结构也很复杂,例如每个IP数据报的转发路由可能不同,所以每次传输的往返时间不同。

如下图,RTO的时间略大于RTT0,但是下一次传输的往返时间RTT1比RTT0要长很多,此时的RTO就不适用于作为RTT1的超时重传时间,会导致没必要的重传。

在这里插入图片描述

所以不能直接使用某次测量得到的RTT样本来计算超时重传时间RTO。

所以我们计算加权平均往返时间RTTs,超时重传时间RTO略大于RTTs。

在这里插入图片描述

RTO计算:

在这里插入图片描述

往返时间RTT比较难测量,如果出现重传,容易导致测量的时间不准。

在这里插入图片描述

利用Karn算法修正版计算RTO的值:

在这里插入图片描述

如下图所示,在第五次传输中,由于RTT5>RTO4的值,所以会发生超时重传,于是此时的RTO5直接等于RTO4的两倍。

在这里插入图片描述

TCP可靠传输的实现

TCP基于以字节为单位的滑动窗口来实现可靠传输。

下图:报文段首部中的窗口字段rwnd的值为20——接收方表明自己的接收窗口尺寸为20字节;确认号的字段为31——接收方希望收到的下一个数据的序号是31。序号30为止的数据已经全部正确接收了。

发送根据这两个字段的值构建自己的发送窗口=20.

在这里插入图片描述

发送方在没有接到确认的情况下可以将发送窗口里面的数据全部发出,凡是没有确认的数据,在确认之前都需要保留,因为可能会超时重传。

在这里插入图片描述

发送窗口的前沿和后沿:

在这里插入图片描述

如何描述发送窗口的状态:

在这里插入图片描述

滑动窗口的滑动过程建议看原视频P63 5.7部分:

【计算机网络微课堂(有字幕无背景音乐版)】

发送窗口的数据已经全部发出后,发送方需要等待接受方的确认才能继续发送数据。

如果迟迟没有确认,重传计时器超时,会重传发生窗口内已发送的数据,并重新启动重传计时器。

在这里插入图片描述

一些其他的要点:

在这里插入图片描述

TCP的连接建立

TCP连接的三个阶段:

在这里插入图片描述

三次握手

TCP规定SYN=1的报文段不能携带数据,但要消耗掉一个序号。

TCP连接由客服端主动发起。

在这里插入图片描述

客户发送对于TCP连接请求的确认的确认是否多余?

在这里插入图片描述

四次挥手

客户发送的TCP报文段中:

序号seq字段的值u为TCP客户进程之前已发送过的、数据的最后一个字节的序号+1;

序号ack字段的值v为TCP客户进程之前已收到的、数据的最后一个字节的序号+1。

服务器发送的:

序号seq字段的值v为TCP服务器进程之前已发送过的、数据的最后一个字节的序号+1(与上面的ack字段值匹配);

序号ack字段的值u+1是对上面客户发送的seq的确认。

在这里插入图片描述

FIN=1和ACK=1表示这是一个TCP释放报文段。

在这里插入图片描述

是否有必要使得客户进入时间等待状态?

是有必要的。如果没有时间等待状态就关闭,那么如果最后一次确认丢失了,服务器就会进入无限等待客户确认的状态里,无法关闭。

在这里插入图片描述

如果客户出现故障,那么服务器怎么关闭连接?

在这里插入图片描述

TCP的首部格式

为了实现可靠传输,TCP采取了面向字节流的方式。

一个TCP报文由首部和数据载荷两部分构成。

**源端口号:**标识发送该TCP报文段的应用进程。

**目的端口号:**标识接收该TCP报文段的应用程序。

在这里插入图片描述

**序号:**指出本TCP报文段数据载荷的第一个字节的序号。

在这里插入图片描述

**确认号:**为n,表明序号到n-1为止的数据都已正确接收,期待接收序号为n的数据。

只有当确认标志位ACK取值为1时,确认号字段才有效。

在这里插入图片描述

在这里插入图片描述

一个全双工通信举例:

可以看到发送端的序号和接收端的确认号是对应的,发送端的确认号和接收端的序号也是对应的。

在这里插入图片描述

**数据偏移:**指出TCP报文段首部的长度。

在这里插入图片描述

保留:占6比特,保留为今后使用,目前为0。

校验和:不重要

**同步标志为SYN:**在TCP建立连接时用来同步序号。

SYN置1表示这是TCP连接报文段。

在这里插入图片描述

终止标志位FIN:用来释放TCP连接。

FIN置1表示这是TCP释放报文段。

在这里插入图片描述

复位标志位RST:用来复位TCP连接。

在这里插入图片描述

推送标志位PSH

在这里插入图片描述

紧急标志位URG和紧急指针

接收方会从数据载荷部分取出紧急数据,直接上交应用进程,而不必在接收缓存中排队。

在这里插入图片描述

扩展首部:

选项:

在这里插入图片描述

填充:

在这里插入图片描述

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

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

相关文章

【Vue】Vue3基础

VUE3基础 1、简介2、创建工程2.1 基于vue-cli创建&#xff08;脚手架webpack&#xff09;2.2 基于vite创建&#xff08;推荐&#xff09;2.3 目录结构2.4 vscode插件推荐 3、核心语法3.1 选项式&#xff08;options API&#xff09;和组合式&#xff08;composition API&#x…

json文件 增删查改

默认收藏夹 qt操作json格式文件... 这个人的 写的很好 我的demo全是抄他的 抄了就能用 —————————— 下次有空把我的demo 传上来 在E盘的demo文件夹 json什么名字

「ETL趋势」FDL数据开发支持版本管理、实时管道支持多对一、数据源新增支持神通

FineDataLink作为一款市场上的顶尖ETL工具&#xff0c;集实时数据同步、ELT/ETL数据处理、数据服务和系统管理于一体的数据集成工具&#xff0c;进行了新的维护迭代。本文把FDL4.1.8最新功能作了介绍&#xff0c;方便大家对比&#xff1a;&#xff08;产品更新详情&#xff1a;…

Profinet IO从站数据 转EtherCAT项目案例

这里是引用 目录 1 案例说明 1 2 VFBOX网关工作原理 1 3 准备工作 2 4 使用PRONETA软件获取PROFINET IO从站的配置信息 2 5 设置网关采集PROFINETIO从站设备数据 5 6 启动ETHERCAT从站转发采集的数据 8 7 选择槽号和数据地址 9 8 选择子槽号 11 9 案例总结 12 1 案例说明 设置…

《昇思25天学习打卡营第12天 | 昇思MindSpore基于MindSpore的GPT2文本摘要》

12天 本节学习了基于MindSpore的GPT2文本摘要。 1.数据集加载与处理 1.1.数据集加载 1.2.数据预处理 2.模型构建 2.1构建GPT2ForSummarization模型 2.2动态学习率 3.模型训练 4.模型推理

揭秘Etched AI:三个哈佛辍学00后挑战英伟达,推出Transformer专用ASIC芯片sohu

人工智能领域最近掀起了一股新的热潮&#xff0c;三位哈佛辍学的00后本科生创建了Etched AI&#xff0c;并成功推出了一款超强AI芯片sohu&#xff0c;直指英伟达的AI芯片帝国。这款芯片被誉为比英伟达H100快20倍&#xff0c;吸引了众多科技界的关注。本文将深入探讨Etched AI及…

五、Spring IoCDI ★ ✔

5. Spring IoC&DI 1. IoC & DI ⼊⻔1.1 Spring 是什么&#xff1f;★ &#xff08;Spring 是包含了众多⼯具⽅法的 IoC 容器&#xff09;1.1.1 什么是容器&#xff1f;1.1.2 什么是 IoC&#xff1f;★ &#xff08;IoC: Inversion of Control (控制反转)&#xff09;总…

带上作弊器,我不得起飞

前言 过去,我们对人工智能既期待又害怕.人类的惰性希望人工智能可以帮助大家从大部分繁重的工作中解放出来,但又害怕它失控. 智能系统的好处 工作方面 自动化与效率提升&#xff1a;可以自动执行许多重复性和低技能的任务&#xff0c;如制造业中的装配、数据输入和办公室的客户…

java的序列化和反序列化

一、概念 序列化是将对象的常态存储到特定的存储介质中的过程。 反序列化是将特定的存储介质中的数据重新构建对象的过程。 问题 为每个对象属性——编写读写代码&#xff0c;过程很繁琐且非常容易出错&#xff0c;如何解决&#xff1f; 二、使用Object Output Stream类实现…

敏捷开发笔记(第9章节)--开放-封闭原则(OCP)

目录 1&#xff1a;PDF上传链接 9.1 开放-封闭原则&#xff08;OCP&#xff09; 9.2 描述 9.3 关键是抽象 9.3.1 shape应用程序 9.3.2 违反OCP 糟糕的设计 9.3.3 遵循OCP 9.3.4 是的&#xff0c;我说谎了 9.3.5 预测变化和“贴切的”结构 9.3.6 放置吊钩 1.只受一次…

Spring专题一:源码编译

下载源码 因为公司使用的是Spring5.2.x所以就下载了这个版本&#xff0c;github源码地址如下&#xff1a; GitHub - spring-projects/spring-framework at v5.2.6.RELEASE&#xff1a; 如果网络不稳定可以使用下载压缩版即可&#xff0c;网络稳定的话还是建议使用git clone …

C语言的数据结构:树与二叉树(哈夫曼树篇)

前言 上篇讲完了二叉树&#xff0c;二叉树的查找性能要比树好很多&#xff0c;如平衡二叉树保证左右两边节点层级相差不会大于1&#xff0c;其查找的时间复杂度仅为 l o g 2 n log_2n log2​n&#xff0c;在两边层级相同时&#xff0c;其查找速度接近于二分查找。1w条数据&am…

今日AI提示词|新媒体运营场景-小红薯笔记通用指令

指令写作的技巧与步骤 明确定义需求 提供足够的上下文 使用简单直白的语言 举例说明 添加限制条件 多次迭代优化&#xff0c;给出详细的要求 小红薯笔记通用指令 从现在开始&#xff0c;你担任我的小红书创作者。你的任务是根据我提供给你的主体&#xff0c;撰写一篇小…

运维锅总详解HAProxy

本文尝试从HAProxy简介、HAProxy工作流程及其与Nginx的对比对其进行详细分析&#xff1b;在本文最后&#xff0c;给出了为什么Nginx比HAProxy更受欢迎的原因。希望对您有所帮助&#xff01; HAProxy简介 HAProxy&#xff08;High Availability Proxy&#xff09;是一款广泛使…

开源项目-商城管理系统

哈喽,大家好,今天主要给大家带来一个开源项目-商城管理系统 商城管理系统分前后端两部分。前端主要有商品展示,我的订单,个人中心等内容;后端的主要功能包括产品管理,门店管理,会员管理,订单管理等模块 移动端页面

汽车电子工程师入门系列——AUTOSAR通信服务框架(上)

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节…

uniapp+vue3开发微信小程序踩坑集

本文主要记录使用uniappvue3开发微信小程序遇见的各种常见问题及注意点。&#xff08;持续更新&#xff09; 问题&#xff1a; 自定义组件为什么有些样式加不上去 给自定义组件增加class的时候&#xff0c;有时候不生效有时候生效&#xff0c;一度让我怀疑自己记忆错乱。后来…

实验 1 图像基本操作

1. 实验目的 ①熟悉 Photoshop 基本操作&#xff1b; ②掌握 Matlab 、PythonOpenCV 中处理图像的基本方法&#xff1b; ③掌握图像的半调转换和抖动转换。 2. 实验内容 ①Photoshop 基本操作&#xff1a;打开图像文件&#xff0c;选择区域&#xff0c;旋转、裁剪图像、图层…

PHP电商系统开发指南数据库管理

回答&#xff1a;数据库管理是电商系统开发的关键&#xff0c;涉及数据的存储、管理和检索。选择合适的数据库引擎&#xff0c;如mysql或 postgresql。创建数据库架构&#xff0c;定义数据的组织方式&#xff08;如产品表、订单表&#xff09;。进行数据建模&#xff0c;考虑实…

华润万家超市卡怎么用?

华润的礼品卡不仅能线下门店使用&#xff0c;还能直接叫送货上门 我最近用积分兑了几张华润卡&#xff0c;但是又没有购物需求&#xff0c;送朋友吧面值又不大&#xff0c;朋友也说用不上 最后朋友建议我在收卡云上把卡出掉&#xff0c;我试了下92折出掉了&#xff0c;价格还…