计算机网络 3-2 数据链路层(流量控制与可靠传输机制)

news2025/7/15 11:02:34

3.4 流量控制与可靠传输机制

流量控制:指由接收方控制发送方的发送速率,使接收方有足够的缓冲空间来接收每个帧

滑动窗口流量控制:一种更高效的流量控制方法。

  • 在任意时刻,发送方都维持一组连续的允许发送帧的序号,称为发送窗口;
  • 接收方也维持一组连续的允许接收帧的序号,称为接收窗口。
  • 发送窗口表示在还未收到对方确认信息的情况下,发送方最多还能发送多少个帧和哪些帧。同理,在接收方设置接收窗口是为了控制可以接收哪些帧和不可以接收哪些帧。 

3.4.2可靠传输机制

a、停止-等待协议 (S-W)

 

  • 如果数据帧丢失,收/发双方会发生什么?
    • 发送方装备了计时器。在一个帧发送后,发送方等待确认,当计时器超时的时候,若仍未收到确认,则重发该数据帧。如此重复,直到该数据帧正确到达为止。

  • 如果接收方检测出数据帧有“差错”并将其丢弃,会发生什么?

        到达接收方的数据帧可能已遭破坏,接收方利用前面介绍的差错检测技术检出后,简单地将该帧丢弃。为了应付这种可能的情况,发送方装备了计时器。在一个帧发送后,发送方等待确认,当计时器超时的时候,若仍未收到确认,则重发该数据帧。如此重复,直到该数据帧正确到达为止

  • 如果收到重复数据帧,收/发双方会怎么做?
    • 数据帧正确而确认帧被破坏,此时接收方已收到正确的数据帧,但发送方收不到确认帧,因此发送方会重传已被接收的数据帧,接收方收到相同的数据帧时会丢弃该帧,并重传一个该帧对应的确认帧。

  • 为什么 S-W不存在“数据帧失序”问题

        因为每发送一个数据帧就停止并等待,所以用1比特来编号就已足够。

        发送的帧交替地用0和1来标识,确认帧分别用ACK0和ACK1来表示,当收到的确认帧有误时,就重传已发送的数据帧。

        若连续出现相同序号的数据帧,则表明发送方进行了超时重传。若连续出现相同序号的确认帧,则表明接收方收到了重复帧。

b、后退N帧协议 (GBN)

正常传输 

 

数据帧丢失

        零号帧丢失之后,一号帧还可以顺利的传到接收方这边,但是接收方检查这个帧的序号。并没有落在接收窗口之内,接收方期待接收到的是零号帧,但现在收到的是一号帧。那这种情况下,接收方肯定得拒绝接收一号帧,直接把它丢弃。与此同时,接收方会给发送方返回最后收到的这个正确帧的ack。即目前收到的最后一个正确帧是三号帧,所以应该给发送方发送ack 3。 

        发送方收到ack 3之后,让发送窗口往右移动一格。那与此同时,由于迟迟没有收到零号帧确认信息,零号帧的计时器超时。零号帧超时之后,发送方会把零号帧及其后面的所有帧都重新传一遍

 

确认帧丢失

        计时器超时,发送方会把零号帧,一号帧,二号帧全部进行重传。接收方会陆续的收到零号,一号,二号这几个帧。但是这几个帧落在了接收窗口之外。那么当接收方收到这种非法的帧的时候,会给发送方返回,目前已经收到的最后一个正确帧的ack。那现在已经收到的最后一个正确帧,即二号帧,所以接收方会给发送方返回ack 2。接收方会把这些重复收到的帧直接丢弃

 

不满足会有什么问题?

接收方返回的ack3丢失且接收窗口正常滑动到下一个帧,发送方零号、一号、二号、三号帧超时重传,发送方这次传过来的零号帧并不是接收方真正想接收的 

c、选择重传协议(SR)

正常传输 

数据帧丢失 

        假设其中的五号帧因为通信线路的故障丢失了。那这样的话,接收方就只能接收到四六七这几个帧,那么收到这几个帧之后,接收方的这个接收窗口可以向右滑动一格。与此同时,把四六七这几个帧的ack返回给发送方

        发送方接下来会收到四六七的ack。在这种情况下,发送窗口只能往右滑动一格,因为五号帧此时还没有被正确的接收。

       由于零号帧已经在发送窗口之内,所以可以发送零号帧,并且设置零号帧的计时器。随着时间的推移,五号帧迟迟没有收到ack,五号帧的计时器会超时。发送方会重传五号帧,并且重置五号帧的计时器。

数据帧因差错丢失

接收方会给发送方。返回四号,六号,七号帧的ack以及五号帧的nak。引入了请求重传机制,即请求5号帧重传

确认帧丢失

        首先确认帧丢失会引起发送方超时重传。超时重传之后,又会导致接收方收到重复帧。那接收方判别重复帧的这个方法就是看这个帧是否落在了接收窗口之外,如果在接收窗口之外,那么就说明它肯定是一个重复帧。每收到一个重复帧接收方,就会给发送方再一次返回这个重复帧的ack。那用这样的方式就可以解决确认帧丢失的问题 

不满足会有什么问题?

        选择重传协议的接收窗口WR和发送窗口WT都大于1,一次可以发送或接收多个帧。若采用n比特对帧编号,需满足条件(

        ①:(否则,在接收方的接收窗口向前移动后,若有一个或多个确认帧丢失,则发送方就会超时重传之前的旧数据帧,接收窗口内的新序号与之前的旧序号出现重叠,接收方就无法分辨是新数据帧还是重传的旧数据帧)。

        还应满足条件②:(否则,若接收窗口大于发送窗口,则接收窗口永远不可能填满,接收窗口多出的空间就毫无意义)

3.4.3 信道利用率分析

S-W 协议的信道利用率

 有时确认帧传输时延会不用加入计算,具体看题目

 GBN、SR协议的信道利用率

 注意这个信道利用率是不能超过一

信道利用率 = 实际的数据传输速率/ 最大带宽 

 

注意:考察帧序号比特数的题目

补充: 

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

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

相关文章

Jenkins配置的JDK,Maven和Git

1. 前置 在配置前,我们需要先把JDK,Maven和Git安装到Jenkins的服务器上。 (1)需要进入容器内部,执行命令:docker exec -u root -it 容器号/容器名称(2选1) bash -- 容器名称 dock…

有效压缩 Hyper-v linux Centos 的虚拟磁盘 VHDX

参考: http://www.360doc.com/content/22/0505/16/67252277_1029878535.shtml VHDX 有个不好的问题就是,如果在里面存放过文件再删除,那么已经使用过的空间不会压缩,导致空间一直被占用。那么就需要想办法压缩空间。 还有一点&a…

网络空间安全(53)XSS

一、定义与原理 XSS(Cross Site Scripting),全称为跨站脚本攻击,是一种网站应用中的安全漏洞攻击。其原理是攻击者利用网站对用户输入内容校验不严格等漏洞,将恶意脚本(通常是JavaScript,也可以…

Spring MVC 框架 的核心概念、组件关系及流程的详细说明,并附表格总结

以下是 Spring MVC 框架 的核心概念、组件关系及流程的详细说明,并附表格总结: 1. 核心理念 Spring MVC 是基于 MVC(Model-View-Controller)设计模式 的 Web 框架,其核心思想是 解耦: Model:数…

金融数据分析(Python)个人学习笔记(6):安装相关软件

python环境的安装请查看Python个人学习笔记(1):Python软件的介绍与安装 一、pip 在windows系统中检查是否安装了pip 打开命令提示符的快捷键:winR,然后输入cmd 在命令提示符中执行如下命令 python -m pip --version…

一周学会Pandas2 Python数据处理与分析-Pandas2一维数据结构-Series

锋哥原创的Pandas2 Python数据处理与分析 视频教程: 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili Pandas提供Series和DataFrame作为数组数据的存储框架。 Series(系列、数列、序列)是一个带有…

DApp实战篇:前端技术栈一览

前言 在前面一系列内容中,我们由浅入深地了解了DApp的组成,从本小节开始我将带领大家如何完成一个完整的DApp。 本小节则先从前端开始。 前端技术栈 在前端开发者速入:DApp中的前端要干些什么?文中我说过,即便是在…

leetcode6.Z字形变换

题目说是z字形变化&#xff0c;但其实模拟更像n字形变化&#xff0c;找到字符下标规律就逐个拼接就能得到答案 class Solution {public String convert(String s, int numRows) {if(numRows1)return s;StringBuilder stringBuilder new StringBuilder();for (int i 0; i <…

[实战] 天线阵列波束成形原理详解与仿真实战(完整代码)

天线阵列波束成形原理详解与仿真实战 1. 引言 在无线通信、雷达和声学系统中&#xff0c;波束成形&#xff08;Beamforming&#xff09;是一种通过调整天线阵列中各个阵元的信号相位和幅度&#xff0c;将电磁波能量集中在特定方向的技术。其核心目标是通过空间滤波增强目标方…

Halcon图像采集

Halcon是一款强大的机器视觉软件&#xff0c;结合C#可以开发出功能完善的视觉应用程序。 基本设置 确保已经安装了Halcon和Halcon的.NET库&#xff08;HalconDotNet&#xff09;。 1. 添加引用 在C#项目中&#xff0c;需要添加对HalconDotNet.dll的引用&#xff1a; 右键点…

基于neo4j存储知识树-mac

1、安装jdk21 for mac(jdk-21_macos-aarch64_bin.dmg) 2、安装neo4j for mac(neo4j-community-5.26.0-unix.tar.gz) 3、使用默认neo4j/neo4j登录http://localhost:7474 修改登录密码&#xff0c;可以使用生成按钮生成密码&#xff0c;连接数据库&#xff0c;默认设置为neo4j…

【学习笔记】文件上传漏洞--二次渲染、.htaccess、变异免杀

目录 第十二关 远程包含地址转换 第十三关 突破上传删除 条件竞争 第十四关 二次渲染 第十五关 第十六关 第十七关 .htaccess 第十八关 后门免杀 第十九关 日志包含 第十二关 远程包含地址转换 延续第十一关&#xff0c;加一个文件头&#xff0c;上传成功&#xff0c…

【OS】Process Management(3)

《计算机操作系统&#xff08;第三版&#xff09;》&#xff08;汤小丹&#xff09;学习笔记 文章目录 5、进程通信&#xff08;Inter-Process Communication&#xff09;5.1、进程通信的类型5.1.1、共享存储器系统&#xff08;Shared Memory System&#xff09;5.1.2、消息传递…

单reactor实战

前言&#xff1a;reactor作为一种高性能的范式&#xff0c;值得我们学习 本次目标 实现一个基于的reactor 具备echo功能的服务器 核心组件 Reactor本身是靠一个事件驱动的框架,无疑引出一个类似于moduo的"EventLoop "以及boost.asio中的context而言&#xff0c;不断…

初阶C++笔记第一篇:C++基础语法

虽然以下大多数知识点都在C语言中学过&#xff0c;但还是有一些知识点和C语言不同&#xff0c;比如&#xff1a;代码格式、头文件、关键字、输入输出、字符串类型等... 1. 初识C 1.1 第一个C程序 编写C分为4个步骤&#xff1a; 创建项目创建文件编写代码运行程序 C的第一条…

无需libpacp库,BPF指令高效捕获指定数据包

【环境】无libpacp库的Linux服务器 【要求】高效率读取数据包&#xff0c;并过滤指定端口和ip 目前遇到两个问题 一是手写BPF&#xff0c;难以兼容&#xff0c;有些无法正常过滤二是性能消耗问题&#xff0c;尽可能控制到1% 大方向&#xff1a;过滤数据包要在内核层处理&…

react实现上传图片到阿里云OSS以及问题解决(保姆级)

一、优势 提高上传速度&#xff1a;前端直传利用了浏览器与 OSS 之间的直接连接&#xff0c;能够充分利用用户的网络带宽。相比之下&#xff0c;后端传递文件时&#xff0c;文件需要经过后端服务器的中转&#xff0c;可能会受到后端服务器网络环境和处理能力的限制&#xff0c;…

Python 字典和集合(常见的映射方法)

本章内容的大纲如下&#xff1a; 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响&#xff08;什么样的数据类型可作为键、不可预知的 顺序&#xff0c;等等&#xff09; 常见的映射方法 映射类型…

Matlab轴承故障信号仿真与故障分析

1.摘要 本文介绍了一个基于Matlab的轴承故障信号仿真与分析程序&#xff0c;旨在模拟和分析轴承内圈故障信号的特征。程序首先通过生成故障信号、共振信号和调制信号&#xff0c;添加噪声和离散化处理&#xff0c;构建模拟的振动信号&#xff0c;并保存相关数据。通过快速傅里…

Linux 进程 | 概念 / 特征 / 状态 / 优先级 / 空间

注&#xff1a; 本文为 “Linux 进程” 相关文章合辑。 未整理去重。 Linux 进程概念&#xff08;精讲&#xff09; A little strawberry 于 2021-10-15 10:23:55 发布 基本概念 课本概念&#xff1a;程序的一个执行实例&#xff0c;正在执行的程序等。 内核观点&#xff…