【计算机网络篇】数据链路层(4.2)可靠传输的实现机制

文章目录

  • 🍔可靠传输的实现机制
    • ⭐停止 - 等待协议
        • 🗒️注意
      • 🔎停止 - 等待协议的信道利用率
        • 🗃️练习题
    • ⭐回退N帧协议
      • 🎈回退N帧协议的基本工作流程
        • 🔎无传输差错的情况
        • 🔎超时重传的情况
          • 🗃️练习
      • 🌹小结
    • ⭐选择重传协议
      • 🎈选择重传协议的基本工作流程
        • 🗃️练习

在这里插入图片描述

🍔可靠传输的实现机制

⭐停止 - 等待协议

如下图所示,收发双方基于因特网进行通信,而不是局限在一条点对点的数据链路。纵坐标是时间
发送方给接收方发送一个数据分组,接收方对其进行差错检测,并向发送方发送确认分组
发送方收到接收方的确认分组后,才能发送下一个数据分组在这里插入图片描述


发送方给接收方发送一个数据分组,但是数据分组丢失了在这里插入图片描述

如下图所示,我们来展示一下解决上述情况的方法
在这里插入图片描述
但是,上面的这种停止 - 等待协议,仍然不能完全实现可靠传输,比如下面的情况
在这里插入图片描述
在这里插入图片描述

🗒️注意

在这里插入图片描述

🔎停止 - 等待协议的信道利用率

发送方发送完一个数据分组后就停止发送,并等待接收方对该数据分组的确认,当收到确认分组后,可以发送下一个数据分组,如此反复进行在这里插入图片描述
TD:发送方发送数据分组所耗费的发送时延
RTT:信号在收发双方之间往返传播所耗费的时间
TA:接收方发送确认分组所耗费的数据时延
TD+RTT+TA:是使用停止等待协议的发送方,从发送一个数据分组开始,到可以发送下一个数据分组为止所经历的时间


由于仅仅是在时间TD内才用来传送有用的数据,也就是数据分组,因此,信道利用率U可以使用下面的公式进行计算
在这里插入图片描述

上述推导没有考虑超时重传的情况
若出现超时重传,对于传送有用的数据信息来说,信道利用率还要降低。
在往返时间RTT相对较大的情况下,为了提高信道利用率,收发双方不适合采用停止-等待协议,而可以选择使用回退N帧(GBN)协议或选择重传(SR)协议。

🗃️练习题

在这里插入图片描述

⭐回退N帧协议

在这里插入图片描述

TD:数据分组的发送时延
RTT:信号在收发双方之间的往返传播时延
由于确认分组一般很短,所以发送时延一般可以忽略(所以没有在图中画出)


如果发送方在未收到接收方发来确认分组的时候,可以连续发送多个数据分组,而不必每发送完一个数据分组,就停下来等待接收方的确认分组,则这种来实现传输方式可以显著提高信道利用率
在这里插入图片描述

注意:在使用流水线传输方式时,发送方不能无限制地连续发送数据分组,否则可能会导致网络中的路由器或接收方来不及处理这些数据分组,进而导致数据分组的丢失,这实际上是对网络资源的浪费。
回退N帧协议采用流水线传输方式,并且利用发送窗口来限制发送方连续发送数据分组的数量,这属于连续ARQ协议。


发送方

在这里插入图片描述
接收方

在这里插入图片描述
在这里插入图片描述

🎈回退N帧协议的基本工作流程

🔎无传输差错的情况

发送方将序号落入发送窗口内的0~4号数据分组,依次连续发送出去,他们经过因特网的传输,正确到达了接收方(也就是没有出现乱序和误码)
在这里插入图片描述

接收方按序接受它们,每接收一个,接收窗口就向前滑动一个位置,并给发送方发送针对数据分组的确认分组
在这里插入图片描述

0~4号确认分组经过因特网的传输,正确到达了发送方,发送方每按序接收一个确认分组,发送窗口就向前滑动一个位置,这样就有新的序号落入了发送窗口在这里插入图片描述
发送方可以将收到确认的数据分组从发送缓存中删除了,而接收方应当从接收缓存中尽快取走已正确接收到的数据分组在这里插入图片描述
从上面的例子可以看出,在无传输差错的情况下,回退N帧协议的信道利用率比停止-等待协议的信道利用率有显著提高。提高的程度取决于发送窗口的大小。

🔎超时重传的情况

发送方将序号落入发送窗口内的0~4号数据分组,依次连续发送出去,它们经过因特网的传输,按序到达了接收方,然而,二号数据分组在传输过程中产生了误码在这里插入图片描述

接收方按序接收0号和1号数据分组,接收窗口向前滑动2个位置,并给发送方发送0号确认分组和1号确认分组
接收方通过2号数据分组中的检错码,检测出了2号数据分组中有误码,因此将其丢弃,接收窗口不能向前滑动,由于3和4号数据分组的序号未落入接收窗口在这里插入图片描述

因此,接收方将它们丢弃,接收窗口不能向前滑动。
另外,接收方每收到一个未按序到达的数据分组(也就是序号未落入接收窗口的数据分组),除将其丢弃外,还给发送方发送针对最近按序接收的数据分组的确认分组


对于本例,最近已按序接收的是1号数据分组,而接收方丢弃了无法按序接收的3号和4号数据分组。因此,接收方会发送2个针对1号数据分组的重复确认
在这里插入图片描述

发送方收到0号和1号确认分组,就将发送窗口向前滑动2个位置,这样就有新的序号5和6落入发送窗口
发送方现在可以将5号和6号的数据分组依次发送出去
在这里插入图片描述
发送方收到针对1号数据分组的2个重复确认,发送方就知道了 接收方并未按序正确接收2号数据分组,而有2个序号未落入接收窗口的数据分组也不能接收 因此被丢弃
在这里插入图片描述

接收方收到5号和6号数据分组,由于它们的序号未落入接收窗口在这里插入图片描述

因此接收方将它们丢弃,接收窗口不能向前滑动
在这里插入图片描述

并且还会给发送方发送2个针对1号数据分组的重复确认。发送方又收到了针对1号数据分组的2个重复确认在这里插入图片描述

至此,发送方已经收到了针对1号数据分组的4个重复确认,发送方就知道了接收方并未按序正确接收2号数据分组。到目前为止,已有4个序号未落入接收窗口的数据分组被接收方丢弃了。发送方此时可以立即重传2号数据分组,也就是在2号数据分组的重传计时器超时前,就提早进行重传。
需要说明的是,发送方收到几个重复确认后就立即开始重传,可由具体实现决定


为了简单起见,对于本例,我们假设发送方收到4个重复确认时仍然不会立刻重传,当2号数据分组发生超时,发送方就将序号落入发送窗口内的超时的 2号数据分组,和其后已发送的3~6号数据分组全部重传
在这里插入图片描述

尽管发送方之前已发送的3 ~ 6号数据分组到达接收方的时候并未出现误码,但是接收方只能接收序号落入接收窗口内的数据分组。因此,一旦2号数据分组出现误码被接收方丢弃,其后连续发送的3 ~ 6号数据分组都要被重传这就是回退N帧协议名称的由来
即:一旦出错,就需要退回去重传已发送过的N个数据分组

从本例可以看出:一个数据分组的差错就可能引起大量数据分组的重传。
在信道质量较差(容易出现误码)的情况下,回退N帧协议的信道利用率并不比停止-等待协议的信道利用率高。

在这里插入图片描述
在这里插入图片描述

🗃️练习

在这里插入图片描述

🌹小结

在这里插入图片描述

⭐选择重传协议

回退N帧协议在无数据分组差错的情况下,其信道利用率比停止—等待协议要高出不少,但是,一个数据分组的差错,就可能引起大量数据分组的重传,而这些重传的数据分组,原本已经正确到达接收方,但由于序号未落入接收窗口内而被接收方丢弃。显然,这些数据分组的重传是对通信资源的严重浪费
为了进一步提高信道利用率,可以设法只重传出现差错的数据分组,这就需要接收窗口WR的尺寸>1,以便先收下失序,但是正确到达接收方且序号落入接收窗口WR内的数据分组,等到所缺数据分组收集齐后,再一并送交上层,这就是选择重传协议在这里插入图片描述
为了使发送方仅重传出现差错的数据分组,接收方不再采用累积确认,而需要对每一个正确接收的数据分组进行逐一确认

🎈选择重传协议的基本工作流程

本例假设采用3个比特给分组编序号,则序号范围是0 ~ (2^3−1)
在这里插入图片描述
发送方将序号落入发送窗口内的0~3号数据分组连续发送给接收方,其中,0号数据分组在传输过程中出现误码
在这里插入图片描述

接收方将其丢弃,接收方将失序但是正确到达接收方且序号落入接收窗口内的1 ~ 3号数据分组进行缓存,并给发送方发送相应的1 ~ 3号确认分组,缓存的1 ~ 3号数据分组暂时不能交付给上层,由于还未收到序号落入接收窗口内的0号数据分组,因此,接收窗口不能向前滑动
在这里插入图片描述

发送方收到失序的1 ~ 3号确认分组后,并不能向前滑动发送窗口,但要记录1 ~ 3号数据分组已被确认(这里的失序是指:没有收到0号数据分组,就收到了1 ~ 3号确认分组,因此,只有0号数据分组被超时重传)在这里插入图片描述
0号数据分组正确到达接收方,接收方正确接收序号落入接收窗口内的0号数据分组,并给发送方发送0号确认分组,接收方现在可以将接收窗口向前滑动4个位置,这样,序号4 ~ 7落入接收窗口内,0号确认分组正确到达发送方
在这里插入图片描述

发送方收到0号确认分组后,将发送窗口向前滑动4个位置,这样,序号4 ~ 7就落入发送窗口内,这样,发送方就可以将序号落入发送窗口内的4 ~ 7号数据分组连续发送出去,而接收方也在等待接收序号落入接收窗口内的4 ~ 7号数据分组在这里插入图片描述
发送方可将发送缓存中 序号已被移除发送窗口 的数据分组删除了,而接收方应尽快将接收缓存中序号已被移出接收窗口的数据分组取走在这里插入图片描述

🗃️练习

在这里插入图片描述

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

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

相关文章

【IC前端虚拟项目】write_path子模块DS与RTL编码

【IC前端虚拟项目】数据搬运指令处理模块前端实现虚拟项目说明-CSDN博客 read_path的代码完成之后,就可以开始整个项目里复杂度最高、bug最多、时序收敛最为困难的模块——write_path的开发了!我自己写过两次这个虚拟项目,每次都是在这里耗时最久,所以大家也可以挑战一下自…

容器三(ArrayList、LinkedList、Vector)

目录 ArrayList 特点和底层实现 LinkedList 特点和底层实现 Vector 向量 ArrayList 特点和底层实现 ArrayList 底层是用数组实现的存储。 特点:查询效率高,增删效率低,线程不安全。 在 List 的多个实现类中,我们一般使用它来处理…

【机器学习】数据探索(Data Exploration)---数据质量和数据特征分析

一、引言 在机器学习项目中,数据探索是至关重要的一步。它不仅是模型构建的基础,还是确保模型性能稳定、预测准确的关键。数据探索的过程中,数据质量和数据特征分析占据了核心地位。数据质量直接关系到模型能否从数据中提取有效信息&#xff…

【公示】2023年度青岛市级科技企业孵化器拟认定名单

根据《青岛市科技企业孵化器管理办法》(青科规〔2023〕1号)(以下简称《管理办法》)、《关于开展2023年度市级科技企业孵化器认定申报工作的通知》,经申报受理、区市推荐、形式审查、专家评审及现场核查等程序&#xff…

leetcode热题100.柱状图中最大的矩形

Problem: 84. 柱状图中最大的矩形 文章目录 题目思路复杂度Code 题目 给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大面积。 示例 1: 输入:hei…

牛客小白月赛89(A,B,C,D,E,F)

比赛链接 官方视频讲解(个人觉得讲的还是不错的) 这把BC偏难,差点就不想做了,对小白杀伤力比较大。后面的题还算正常点。 A 伊甸之花 思路: 发现如果这个序列中最大值不为 k k k,我们可以把序列所有数…

【QT学习】2.信号与槽,标准信号与槽,自建信号,自建槽

1.主函数的进一步解释 2.信号与槽的简单例子 connect(&but1, //发送者&QPushButton::pressed, //发送触发事件this, //接受者&MainWindow::close); //接受数据后处理操作 connect() 参数1&#xf…

unity学习(76)--窗口化和后台运行

1.通过如下方式将编译的游戏设置为窗口模式。 成功: 2.现在只有鼠标点击的窗体游戏运动,其他窗体游戏都会卡住。 2.1build setting中 2.2unity内部Project Settings 也被同步修改了

深度学习故障诊断实战 | 数据预处理之创建Dataloader数据集

前言 本期给大家分享介绍如何用Dataloader创建数据集 背景 示例代码 from torch import nn import torch import os import numpy as np import pandas as pd import matplotlib.pyplot as plt import time import torch.functional as F from sklearn.manifold import TSNE…

【漏洞复现】大华综合安防监控管理平台 Digital Surveillance System系统存在RCE漏洞

免责声明:文章来源互联网收集整理,请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失,均由使用者本人负责,所产生的一切不良后果与文章作者无关。该…

《亮数据:爬虫数据采集行业痛点的利器》

❤️作者主页:小虚竹 ❤️作者简介:大家好,我是小虚竹。2022年度博客之星评选TOP 10🏆,Java领域优质创作者🏆,CSDN博客专家🏆,华为云享专家🏆,掘金年度人气作…

npm救赎之道:探索--save与--save--dev的神秘力量!

目录 1. --save和--save-dev是什么?2. 区别与应用场景--save--save-dev 3. 生产环境与开发环境4. 实际应用示例--save--save-dev 5. 总结 在现代软件开发中,npm(Node Package Manager)扮演着不可或缺的角色,为开发者提…

第二十一章 Jquery ajax

文章目录 1. jquery下载2. jquery的使用3. jquery页面加载完毕执行4. jquery属性控制6. 遍历器 2. ajax1. 准备后台服务器2. ajax发送get请求3. ajax发送post请求 1. jquery下载 点击下载 稳定版本1.9 2. jquery的使用 存放到html文件的同级目录 3. jquery页面加载完毕执行…

Colorize (Texture Color Palette Modifier)

Colorize提供了无与伦比的区域颜色调整和效果控制,如使用纹理调色板的模型的发射、金属反射和模拟金属遮挡。 Colorize彻底改变了你在Unity中为3D模型添加颜色和生命的方式。无论你是一个独立开发者、艺术家,还是一个大型团队的一员,Colorize都提供了一套直观、强大的工具,…

Tomcat配置https

前言:本文内容为实操记录,仅供参考! 一、证书 CA证书申请下载不赘述了。 二、上传证书 进入tomcat根目录,conf同级目录下创建cert文件夹,并将证书两个文件上传到该文件夹; 三、编辑conf/server.xml文件 ① …

3723. 字符串查询:做题笔记

目录 思路 代码 注意点 3723. 字符串查询 思路 这道题感觉和常见的前缀和问题不太一样,前缀和的另一种应用:可以统计次数。 这道题我们想判断一个单词的其中一段子序列A是否可以通过重新排列得到另一段子序列B。 我看到这道题的时候想着可能要判…

华为Mate60RS非凡大师和华为Mate50RS保时捷对比

外观设计:Mate 60RS采用了更加高端的材质和工艺,相比Mate 50RS更加坚固耐用,同时具备更多的细节设计,如更加精致的纹理和镀铬边框等。 屏幕显示:Mate 60RS的屏幕分辨率更高,达到了32001440像素&#xff0c…

Excel·VBA数组分组问题

看到一个帖子《excel吧-数据分组问题》,对一组数据分成4组,使每组的和值相近 目录 代码思路1,分组形式、可分组数代码1代码2代码2举例 2,数组所有分组形式举例 这个问题可以转化为2步:第1步,获取一组数据…

线程的状态:操作系统层面和JVM层面

在操作系统层面,线程有五种状态 初始状态:线程被创建,操作系统为其分配资源。 可运行状态(就绪状态):线程被创建完成,进入就绪队列,参与CPU执行权的争夺。或因为一些原因,从阻塞状态唤醒的线程…

车道线检测项目 | 基于lanenet实现的实时车道线检测

项目应用场景 面向自动驾驶场景的车道线检测场景,项目的特点是能够达到实时的车道线检测 项目效果: 项目细节 > 具体参见项目 README.md (1) 安装依赖 pip3 install -r requirements.txt (2) 测试图片 python tools/test_lanenet.py --weights_pat…