计网----累积应答,TCP的流量控制--滑动窗口,粘包问题,心跳机制,Nagle算法,拥塞控制,TCP协议总结,UDP和TCP对比,中介者模式

news2024/11/25 4:39:38

计网----累积应答,TCP的流量控制–滑动窗口,粘包问题,心跳机制,Nagle算法,拥塞控制,TCP协议总结,UDP和TCP对比,中介者模式

一.累积应答

1.什么是累计应答

每次发一些包,收到这些包之后,统一回复一个ACK(累计到一定数量的包后统一给一个回复,告诉前面的包都收到了)

2.累计应答用在哪

累计应答用在TCP的流量控制–滑动窗口

二.TCP的流量控制–滑动窗口

TCP的流量控制是通过滑动窗口来实现的

1.什么是窗口

窗口概念:

TCP是没发送一个数据,都要进行一次确认应答。当上一个数据包收到了应答了,再发送下一个。这个模式就有点像我和你面对面聊天,你一句我一句。但这种发放的缺点是效率比较低的

有了窗口,就可以指定窗口的大小。窗口大小就是指无需等待确认应答,而可以继续发送数据的最大值

2.滑动窗口

看下图进行了解

在这里插入图片描述

提示

1.图中每一个数字就是一个包

2.图中蓝色的框就是滑动窗口(这里的滑动窗口的大小是20)

3.滑动窗口前面的数据是已发送并收到ACK确认的数据

分析

发送方统一发送滑动窗口中的数据包,如果接收方收到了滑动窗口中所有的包就统一回复一个ACK(这里是回复一个52的ACK)

注意

如果发送方所发送的数据丢失了,这里假设39号包丢失了其他的包都收到了,那么就会返回一个39的ACK,告诉发送方下一次从39号的数据包开始发,39号之后已经处理的包就不再处理了,因为已经处理过了

如果发送方所发送的数据丢失了,这里假设39号包,40号包,50号包丢失了其他的包都收到了,那么会返回一个39的ACK(返回的ACK的值是能收到的连续的序号的最大的那个),告诉发送方下一次从39号的数据包开始发,并且已经处理的包就不再处理了,因为已经处理过了

3.流量控制

1.什么是流量控制

所谓流量控制,主要是接收方收递信息给发送方,使其不要发送数据太快,是一种端到端的控制。主要的方式就是返回的ACK中会包含自己的接收窗口大小,并且利用大小来控制发送方的数据发送

看下图进行了解

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

注意:当接收窗口变为0时,发送窗口也会变为0,发送端就会暂停发送数据。然后等应用程序从接收缓冲区里读出数据的时候,接收端的接收窗口就会变大,然后告诉发送端,发送端的发送窗口也会变大,之后发送端就可以继续发送数据了

三.粘包问题

1.什么是粘包

tcp是字节流传输,是一种没有边界的,可以合并的传输数据方式。

合并就要能拆开,拆不开就是粘包

举例:接收方接收数据之后存在接收缓冲区里,等待应用程序来读,但如果第一次接收的数据,应用程序没有读,第二次接收的数据会写在第一次接收的数据的后面,那这样数据就变成一块了,然后当应用程序来读的时候就没有办法区分这些数据哪些是第一次接收的数据,哪些是第二次接收的数据。

2.解决粘包问题

1.设置标志位(起始/结束标志位)

起始标志位缺点:只有一个包,没收到第二个包,不知道什么时候第一个包结束

起始/结束标志位的共同缺点:没有办法避免用户发的包里面的内容和标志位重复

应用场景:已知要发送的内容都是什么

2.固定包大小

缺点:当用户发送的单个包的数据小于固定包大小就会浪费空间

应用场景:下载文件(文件比较大)

3.先发数据长度,然后再发数据包

缺点:多发了一个数据长度的包,浪费了时间和空间

应用场景:

4.短连接 :每次连接发送一个包然后就断开

缺点:每次连接和断开都会花时间

应用场景:访问网站

注意:解决粘包问题没有最好的方法,只有最合适的方法

四.心跳机制

1.应用场景:

在长连接下,有可能很长一段时间都没有数据连接。理论上来说,这个连接时一直保持连接的,但是实际情况中,如果中间节点出现什么故障时难以知道的。更要命的是,有的节点(防火墙)会自动把一定时间之内没有数据交互的连接给断掉。在这个时候,就需要我们的心跳包了,用于维持长连接,保活

2.什么是心跳机制

就是每隔几分钟(自己设定时间)发送一个固定消息给服务端,服务端收到后回复一个固定消息。如果服务端几分钟内没有收到客户端信息则视客户端断开

3.心跳包的发送,通常有两种技术:

1.应用层自己实现的心跳包(比较灵活)

2.使用SO_KEEPALIVE套接字选项(TCP协议提供的,比较固定)

五.Nagle算法

1.Nagle算法的作用

Nagle算法是为了尽可能发送大块数据,避免网络中充斥这许多小数据块

(路由器转发数据的时候,不论数据包多大,转发的时间都是相同的,如果包的个数多的话,那路由器转发的时间就多)

2.Nagle算法的规则

1.如果包长度达到MSS(最大报文长度),则允许发送

2.如果该包含有FIN,则允许发送

3.设置了TCP_NODELAY选项时(相当于关闭了Nagle算法),则允许发送

4.设置了TCP_CORK选项时若所有发出去的小数据包(包长度小于MSS)均被确认,则允许发送

5.上述条件都未满足,但发生了超时(一般为200ms),则立即送出。

​ Nagle算法默认是打开的,如果对于一些需要小数据包交互的场景的程序,比如,telnet或ssh这样的交互性比较强的程序,则需要关闭Nagle算法。关闭Nagle算法的方法:

int value=1;
setsockopt(sock_fd,IPPROTO_TCP,TCP_NODELAY,(char*)&value,sizeof(int));

六.拥塞控制

1.什么是拥塞

网络中的链路容量和交换节点中的缓存和处理及都有着工作的极限,当网络的需求超过它们的工作极限时,就出现了拥塞。网络中出现拥塞时,如果继续发送大量数据包,可能会导致数据包时延、丢失等,这时TCP就会重传数据,但是一重传就会导致网络的负担更重,于是会导致更大的延迟以及更多的丢包,这个情况就会进入恶性循环被不断地放大…

所以我们就需要用到拥塞控制,用了拥塞控制之后输入负载与吞吐量之间的关系

在这里插入图片描述

2.拥塞控制

TCP的四种拥塞控制算法:

慢开始、拥塞避免、快重传、快恢复

1.慢开始与拥塞避免
1.拥塞窗口

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

(注意:发送方能发送的最大数据量取决于滑动窗口和拥塞窗口二者中小的那个)

2.慢开始算法

慢开始算法的思路就是,不要一开始就发送大量的数据,先探测一下网络的拥塞成都,也就是说由小到大逐渐增加拥塞窗口的大小。

为了防止cwnd增加过大引起网络拥塞,还需设置一个慢开始门限ssthresh状态变量。ssthresh的用法如下

当cwnd<ssthresh时,使用慢开始算法

当cwnd>ssthresh时,改用拥塞避免算法。

当cwnd=ssthresh时,慢开始与拥塞避免算法任意。

3.拥塞避免算法

拥塞避免算法让拥塞窗口缓慢增长,即每经过一个往返时间RTT就把发送方的拥塞窗口cwnd加1,而不是加倍。这样拥塞窗口按线性规律缓慢增长

4.看图理解慢开始算法和拥塞避免算法

在这里插入图片描述

提示:

​ 1.当使用慢开始算法下一传输伦次所得的拥塞窗口的值大于了ssthresh值,那下一传输伦次所得的拥塞窗口的值变为ssthresh的值,接下来改用拥塞避免算法

​ 2.当发生超时重传时(图中拥塞窗口为24那一点发生了超时重传),判断网络可能出现拥塞,进行图中的那两个步骤

2.快重传和快恢复

注意:快重传比超时重传快

1.快重传

看图理解快重传

在这里插入图片描述

图中发送方发送的M3丢失了,发送方继续发送了M4,M5,M6,这时接收方就会连续重新确认M2,那就会立即重传M3

2.快恢复

快恢复就是在触发快重传之后,将cwnd变为ssthresh+3

3.看图理解快重传和快恢复

在这里插入图片描述

提示:图中当拥塞窗口为12那一点发生了超时重传

注意:慢开始、拥塞避免快重传和快恢复这四个算法是一起使用从而实现拥塞控制的

七.TCP协议总结

1.TCP协议是面向连接的、可靠的传输,基于字节流的传输方式

2.面向连接指发送数据之前必须在双端建立连接,建立连接使用“三子握手”

3.可靠传输:sep和ack

4.基于字节流的传输:粘包问题

解决方案:1.先发数据长度,然后再发数据包 2.设置标志位(起始/结束标志位)3.固定包大小 4.短连接 :每次连接发送一个包然后就断开

5.为什么TCP是可靠的

1.三次握手和四次回收

2.重传和确认机制

3.合理的手段

4.校验重新排序

5.滑动窗口----流量控制

6.拥塞窗口----4中拥塞控制算法

6…TCP可以发广播吗

TCP是一对一传输的,理论上是不能发广播的

问题一:微信用的是TCP协议,为什么可以一次跟很多人聊天

我们每个人(客户端)都只跟服务端聊天,然后服务端帮我们转发给其他人(其他客户端)

问题二:QQ是使用UDP实现的,那为什么我们在使用QQ的时候不会出现数据丢失

在应用层做seq和ack的功能,保证传输数据可靠

使用一个队列,把我们要发送的数据放到队列中去并编上号,然后把包发出去,包发出去的同时,起一个定时器进行计时,当接收端收到之后返回一个ack看是否超时,没超时就继续发下面的包,超时了就重新发送一次

问题三:QQ是使用UDP实现的,为什么要在应用层实现seq和ack的功能,保证传输数据可靠,为什么不直接用TCP呢

因为UDP比TCP快,因为我们只需要使用TCP的一部分功能,UCP加上TCP的一部分功能还是比TCP快

八.UDP和TCP对比

看下图

在这里插入图片描述

九.中介者模式

设计模式入门中一个模式叫做中介者模式(mediator)。用一个中介对象来封装一系列的对象交互。中介者是各个对象不需要显示地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。简单来说就是解决多组件之间的通信问题,使得组件之间的通信变得简单

看下图进行理解

在这里插入图片描述

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

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

相关文章

【小尘送书-第十一期】《算法秘籍》:算法是编程的基石,开发的核心

大家好&#xff0c;我是小尘&#xff0c;欢迎你的关注&#xff01;大家可以一起交流学习&#xff01;欢迎大家在CSDN后台私信我&#xff01;一起讨论学习&#xff0c;讨论如何找到满意的工作&#xff01; &#x1f468;‍&#x1f4bb;博主主页&#xff1a;小尘要自信 &#x1…

【RocketMQ】深入剖析延迟消息核心实现原理

一、背景 电商相关业务的时候&#xff0c;有一个常见的需求场景是&#xff1a;用户下单之后&#xff0c;超过半小时不支付&#xff0c;就取消订单。现在我们在淘宝京东买东西&#xff0c;或者通过美团点外卖&#xff0c;下单之后&#xff0c;如果不在指定时间内支付&#xff0…

个人实用的街头防身自卫术,男女必学的防身实战技能

一、教程描述 本套教程&#xff0c;大小455.93M&#xff0c;共有17个文件。 二、教程目录 实战防身术01、街头防身自卫术示例.mp4 实战防身术02、街头防身自卫术序言.mp4 实战防身术03、腕部被抓解脱.mp4 实战防身术04、胸襟被抓解脱.mp4 实战防身术05、腰部被抓解脱.mp…

应用在全固态激光雷达中的ALS环境光传感芯片

全固态扫描式激光雷达系统这一创新性技术在多个领域都有着巨大的潜力&#xff0c;将改变未来科技格局。本文将探讨这一革命性的发明&#xff0c;以及它在自动驾驶、无人机、工业自动化、环境监测等领域的关键应用。 传统激光雷达系统通常使用复杂的机械装置&#xff0c;这些部…

如何上传自己的Jar到Maven中央仓库

在项目开发过程中&#xff0c;我们常常会使用 Maven 从仓库拉取开源的第三方 Jar 包。本文将带领大家将自己写好的代码或开源项目发布到 Maven中央仓库中&#xff0c;让其他人可以直接依赖你的 Jar 包&#xff0c;而不需要先下载你的代码后 install 到本地。 注册帐号 点击以…

基于Pymavlink协议的BlueROV开发

1 BlueROV概述 1.1 什么是ROV 维基百科遥控潜水器&#xff08;Remotely operated underwater vehicle&#xff0c;缩写ROV&#xff09;是一个无人的水下航行器&#xff0c;以电缆连接到母船的人员操作。常搭载水下光源和照相机、摄影机、机械手臂、声纳等。因为具有机械手臂&a…

华为OD机试 - 找朋友(Java 2023 B卷 100分)

目录 专栏导读一、题目描述二、输入描述三、输出描述大白话解释一下就是&#xff1a;1、输入&#xff1a;2、输出&#xff1a;3、说明 四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专…

安装node-sass安装失败(Failed at the node-sass@4.14.1 postinstall script.)

npm i安装依赖&#xff0c;安装node-sass失败 全局设置淘宝镜像&#xff0c;还是下载不下来。下载不下来可能是因为默认从github上去下载node-sass&#xff0c;而国内经常连不上或者网络不好。可以单独下载 npm i node-sass4.14.1 --sass_binary_sitehttps://npm.taobao.org/…

Maven多环境下 active: @profileActive@报错问题解决

1.报错&#xff1a; Caused by: org.yaml.snakeyaml.scanner.ScannerException: while scanning for the next token found character that cannot start any token.(Do not use for indentation) 2.解决办法&#xff1a; 在主pom的文件下&#xff0c;重新加载&#xff1a;

模型可解释性

模型可解释性 前言导读Background1、为什么需要可解释性&#xff1f;2、诞生背景3、研究现状4、常见的模型可解释性方法4.1 基于模型自身的可解释性1&#xff09;Explanation Generation2&#xff09;Prototype Network 4.2 基于结果的可解释性 5、应用前景6、面临挑战 前言导读…

基于ssm的校园快递物流管理系统(java+jsp+ssm+javabean+mysql+tomcat)

博主24h在线&#xff0c;想要源码文档部署视频直接私聊&#xff0c;9.9拿走&#xff01; 基于javawebmysql的ssm校园快递物流管理系统(javajspssmjavabeanmysqltomcat) 运行环境&#xff1a; Java≥8、MySQL≥5.7、Tomcat≥8 开发工具&#xff1a; eclipse/idea/myeclipse/s…

php实现普通和定时跳转的几种方式

一、普通跳转 1、使用header函数&#xff1a;通过设置HTTP头部信息实现页面跳转。可以使用Location头部指定跳转的URL。例如&#xff1a; header("Location: http://www.example.com"); exit(); 2、使用JavaScript&#xff1a;可以使用JavaScript的window.location…

倾斜摄影三维模型的根节点合并的并行处理技术分析

倾斜摄影三维模型的根节点合并的并行处理技术分析 倾斜摄影三维模型的根节点合并是指将多个倾斜摄影拍摄得到的三维模型中的根节点进行合并&#xff0c;以减少模型大小和复杂度。在处理大规模的倾斜摄影数据时&#xff0c;传统的串行处理方法效率较低&#xff0c;因此需要使用并…

Shiro安全框架

一、与SpringBoot整合 ①&#xff1a;框架整合 1. 创建SpringBoot项目 环境&#xff1a; jdk: 1.8SpringBoot: 2.5.14 2. 整合MyBatis根据实体类生成表 可查看文章&#xff1a;https://juejin.cn/post/7234324615015776315 按照以上笔记配置后在补充一下代码 依赖MyBatisP…

QML 中TextField输入框和下划线的设定

1.TextField的默认显示方式是输入框&#xff0c;如下所示: TextField { placeholderText: qsTr("Enter name") } 但是也有这样显示的,它变成了下划线: 在属性设置中是找不到相关设置&#xff0c;结果在mian.cpp中发现了一行代码会影响效果。这行代码是…

网工实验笔记:IPv6(配置6to4隧道)

1. 实验目的 熟悉6to4隧道的应用场景 掌握6to4隧道的配置方法 2. 实验拓扑 实验拓扑如图所示&#xff1a; 想要华为数通配套实验拓扑和配置笔记的朋友们点赞关注&#xff0c;评论区留下邮箱发给你! 3. 实验步骤 &#xff08;1&#xff09;配置IP地址 AR1的配置 …

ActiveMQ反序列化漏洞(CVE-2015-5254)复现

漏洞描述 Apache ActiveMQ 是由美国 Pachitea &#xff08;Apache&#xff09; 软件基金会开发的开源消息传递中间件&#xff0c;支持 Java 消息传递服务、集群、Spring 框架等。 Apache ActiveMQ 版本 5.x 之前的 5.13.0 安全漏洞&#xff0c;该漏洞由程序导致&#xff0c;不…

运动蓝牙耳机哪个品牌好?值得推荐的运动耳机分享

​对于我来说&#xff0c;运动和音乐是生活中不可或缺的元素。无论是在室内还是在户外锻炼&#xff0c;我都会选择一款适合的运动耳机&#xff0c;播放自己喜欢的音乐&#xff0c;让自己放松身心。在选择运动耳机时&#xff0c;我会考虑到它的舒适度、音质、耐用的性能以及防水…

led灯对眼睛有伤害吗?精选高品质的护眼台灯

在大家的认知中led灯最大的危害就是有蓝光辐射&#xff0c;其实在如今科技发达的时代&#xff0c;很多led灯对蓝光的处理技术都已经非常成熟的了&#xff0c;有些led灯具甚至做到了RG0无蓝光危害的。只要我们挑选一款光源合适、质量合格的产品&#xff0c;正确的使用基本都不会…

Kubernetes的介绍

目录 Kubernetes概述 1、作用 2、官网 3、K8S的主要功能 Kubernetes 集群架构与组件 1、核心组件 1&#xff09;Kube-apiserver 2&#xff09;Kube-controller-manager 3&#xff09;Kube-scheduler 4&#xff09;etcd 5&#xff09;Kubelet 6&#xff09;Kube-Pro…