Linux学习(15)-网络编程:滑动窗口、拥塞控制、udp

news/2024/10/18 18:23:19/

本节学习内容

1.滑动窗口(1.滑动窗口的作用2.如果如果接收端填充的接收窗口为0,发送端接下来怎么处理3.糊涂窗口综合征4.tcp中nagle算法是什么)

2.拥塞控制

3.udp协议特点及编程流程

本节可能会用到的指令

ifconfig查看自己的ip地址

ping+ ip地址验证通信是否连接

netstat -natp显示当前进程的端口号及数据

一、滑动窗口

1.滑动窗口的作用:

TCP协议是利用滑动窗口实现流量控制。(流量控制:就是是发送方的发送速率不要太快,使接收方及时接收)

在TCP报头中,有一段叫做通告窗口,这一字段由接收端填充,用于告诉发送端自己的接收缓冲区还可以接受多少数据。这个窗口位置会随发送端数据发送和接收端数据接收而不断滑动,所以称为滑动窗口。

2.如果接收端填充的接收通知窗口为0,发送端接下来怎么处理?

假设A主机向B主机发送数据,当B的窗口为0,则A不能再向B发送数据。只能等到B的应用进程将缓存中的数据清空,才能接受新的值。但这里有一个问题,当B的应用进程清空缓存后,并不会主动告知A(TCP当且仅当在它有数据需要确认和发送时才会发送报文段给主机A),这样主机A不可能知道主机B的接收缓存已经有新的空间了。

解决:TCP规范中规定,当主机B的接受窗口为0时,主机A继续发送只有一个字节数据的报文段。这个报文段会被接收方确认。最终缓存将开始清空,并且确认报文段将包含一个非0的值。

3.什么叫糊涂窗口综合征

当发送端应用进程产生数据很慢、或接收端应用进程处理接收缓冲区数据很慢,或二者都有;就会使应用进程间传送的报文段很小,特别是有效载荷很小。 极端情况下,有效载荷可能只有1个字节;而传输开销有40字节(20字节的IP头+20字节的TCP头) 这种现象就叫糊涂窗口综合症

解决方法:

延时确认

当一个报文段到达时并不立即发送确认。接收端在确认收到的报文段之前一直等待,直到入缓存有足够的空间为止。延迟的确认防止了发送端的TCP滑动其窗口。当发送端的TCP发送完其数据后,它就停下来了。这样就防止了这种症状。

4.TCP中Nagle算法是什么?

nagle算法的核心思想是允许网络中最多只能有一个小分组被发送,而待发送的其它小分组会被重新分组成一个”较大的”小分组,等收到上一个小分组的应答后再发送

二、拥塞控制

1.什么是拥塞控制?

所谓的拥塞控制是防止过多的数据注入到网络中而使路由器或链路过载。

2.拥塞控制的几种方法

慢启动

拥塞避免

快速重传

快速恢复

如图

三、udp

1.udp协议特点

UDP提的为无连接、不可靠的数据报服务

无连接:可以做到多个客户端同时向服务器端发送数据(客户端不需要申请与服务器端建立连接)

不可靠:发送给对方的数据,如果对方一次性收不完就会丢失

udp协议各端流程如图

2.udp协议编程

udp服务器端代码如下

udp客户端如下

 

运行结果如下

4.tcp协议和udp协议应用

tcp:TCP适用于对准确性要求较高的场景,如网页浏览、电子邮件和文件传输等

udp:UDP由于其简单性和不可靠性,在网络游戏、流媒体和实时通信等场景中广泛应用


http://www.ppmy.cn/news/1517969.html

相关文章

MacOS上升级Ruby版本

在MacOS上升级Ruby版本,可以通过RVM(Ruby Version Manager)来完成。以下是升级Ruby版本的步骤: 安装RVM:打开终端,运行以下命令安装RVM:curl -sSL https://get.rvm.io | bash -s stable 加载RVM…

AI产品经理系列:如何应对AI时代?

目录 简介 应对策略 产业链 作者简介 简介 虽然说 AI 本身无上限, 因为软件、算法可以无限制迭代、升级...... 但是他所需的能源、所需的硬件支持是有限制的。 至少在很长一段时间内,这些问题很难快速解决。 这也就意味着, 当前的 AI 更多的是互联网时代的一种延续, 在…

★ 算法OJ题 ★ 力扣202 - 快乐数

Ciallo&#xff5e;(∠・ω< )⌒☆ ~ 今天&#xff0c;我将和大家一起做一道双指针算法题--快乐数~ 目录 一 题目 二 算法解析 三 编写算法 一 题目 202. 快乐数 - 力扣&#xff08;LeetCode&#xff09; 二 算法解析 题⽬告诉我们&#xff0c;当我们不断重复操作…

数学基础 -- 线性代数之行阶梯形

行阶梯形 行阶梯形&#xff08;Row Echelon Form, REF&#xff09;是线性代数中用于简化矩阵形式的一种方法&#xff0c;常用于求解线性方程组。矩阵经过行变换&#xff08;如高斯消元法&#xff09;后可以转换为行阶梯形&#xff0c;它具有以下特点&#xff1a; 行阶梯形的定…

HTML静态网页成品作业(HTML+CSS)——游戏战地介绍设计制作(4个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有4个页面。 二、作品演示 三、代…

【uniapp重大bug】uni-data-select的localdata改变,也会触发@change方法

bug描述 uni-data-select的下拉列表值localdata是动态获取的&#xff0c;且绑定了change方法&#xff0c;在页面加载后&#xff0c;请求localdata的列表数据&#xff0c;给localdata重新赋值&#xff0c;此时发现自动触发了change方法 当前uni版本&#xff1a;^2.0.2-30709202…

day-43 盛最多水的容器

思路 双指针&#xff1a;首先令i0,jheight.length-1,选取短板&#xff08;即Math.min(height[i],height[j])&#xff09;,然后将短板向内移动&#xff0c;直达i>j即可得到答案。 解题过程 短板向内移动&#xff1a;水的容量可能增大 长板向内移动&#xff1a;水的容量不可能…

javascript网页设计案例

以下是一些使用 JavaScript 进行网页设计的案例&#xff0c;这些案例展示了 JavaScript 在前端开发中的强大功能和灵活性。每个案例都包含了基本的实现思路和代码示例。 图片画廊&#xff08;Image Gallery&#xff09; 功能&#xff1a;展示一组图片&#xff0c;并支持点击放…