【计算机网络笔记】传输层——可靠数据传输原理之Rdt协议

news2025/7/23 19:13:28

系列文章目录

什么是计算机网络?
什么是网络协议?
计算机网络的结构
数据交换之电路交换
数据交换之报文交换和分组交换
分组交换 vs 电路交换
计算机网络性能(1)——速率、带宽、延迟
计算机网络性能(2)——时延带宽积、丢包率、吞吐量/率
计算机网络体系结构概念
OSI参考模型基本概念
OSI参考模型中非端-端层(物理层、数据链路层、网络层)功能介绍
OSI参考模型中端-端层(传输层、会话层、表示层、应用层)功能介绍
TCP/IP参考模型基本概念,包括五层参考模型
网络应用的体系结构
网络应用进程通信
网络应用对传输服务的需求
Web应用之HTTP协议(涉及HTTP连接类型和HTTP消息格式)
Cookie技术
Web缓存/代理服务器技术
传输层服务概述、传输层 vs. 网络层
传输层——多路复用和多路分用
传输层——UDP简介


  • 系列文章目录
  • 可靠数据传输原理
  • Rdt1.0:可靠信道
  • Rdt2.0:产生位错误的信道
  • Rdt2.1:应对ACK/NAK破坏
  • Rdt2.2:无NAK消息协议
  • Rdt3.0


文章较长,有4013字,建议收藏后慢慢品读 💖


可靠数据传输原理

可靠数据传输是计算机网络的核心问题之一。

可靠指的是数据在传输的过程中不出错(比如不会发生某一位翻转的情况)、数据不丢失、分组的顺序不乱

可靠数据传输依靠可靠数据传输协议

我们需要认识到哪些因素导致信道的不可靠传输,才能解决问题。

我们将用Rdt这个缩写代替可靠数据传输。

可靠数据传输协议基本结构:接口

在这里插入图片描述

下面来介绍可靠数据传输协议。我们循序渐进地来设计可靠数据传输协议的发送方和接收方。并且只考虑单向数据传输,但控制信息双向流动。此外,我们利用有限状态机(Finite State Machine, FSM)刻画传输协议。

在这里插入图片描述

  • 用圆圈代表当前所处的状态,中间的箭头代表状态间的转换,箭头上有文字并且划有横线,横线上方写的是引起状态变迁的事件(event),横线下方写的是进行状态转换过程中要采取的活动(action)。

Rdt1.0:可靠信道

Rdt1.0研究在可靠信道上进行可靠数据传输。这是理想的状态。也就是说不会发生错误,也不会丢弃分组。

因为是可靠信道,所以发送方和接收方之间不需要进行控制信息的交换。发送方只需要发出去就好了,它知道数据会被可靠地传输。这样他俩之间没有交互信息,所以发送方和接收方的FSM独立。

发送方就一个状态,当上层调用rdt_send函数传来数据这个事件发生后,要采取一个活动,也就是创建packet分组然后调用信道上的udt_send将分组发出去。发出去之后由于确信分组会百分百正确地交付,所以就回到这个状态继续等待。

在这里插入图片描述

接收方也就一个状态,即等待下层的调用(rdt_rcv(packet)),然后提取数据交给上层,接着又回到等待状态。

在这里插入图片描述


Rdt2.0:产生位错误的信道

从2.0开始研究更贴近实际的情况,也就是不可靠信道上的可靠数据传输协议。

Rdt2.0研究这样的信道:可能产生位错误(比如0变1,1变0)的信道并且只可能产生这个错误。

要解决的问题:接收方首先需要判断数据是否出错,如果错了,需要重新传输数据。作为发送方,它是不知道分组在传输过程中是否出错的,需要接收方来告知。

  • 辨别数据是否出现位错误:利用校验和检测位错误
  • 从错误中恢复:
    • 引入确认机制(Acknowledgements, ACK):接收方显式地告诉发送方是否已正确接收分组。如果正确接收,就是ACK;如果分组有错误就是NAK
    • 发送方收到NAK后,重传分组。

基于这种ACK机制、NAK机制和重传机制的rdt协议称为ARQ(Automatic Repeat reQuest)协议

总结Rdt2.0中引入的新机制:

  • 差错检测
  • 接收方反馈控制消息: ACK/NAK
  • 重传

发送方现在有2个状态,一个是等待上层调用,一个是等待接收方控制消息。这种协议是停 —等协议

在这里插入图片描述

接收方的状态只有一个:

在这里插入图片描述

Rdt2.1:应对ACK/NAK破坏

为什么要改进?也就是说Rdt 2.0有什么缺陷?要是控制消息出错怎么办?因为ACK和NAK在传给发送方的时候也是有可能出现位错误的,那么这个时候发送方就识别不了控制信息,就会发生死锁。

可能的解决方案:

  • 为ACK/NAK增加校验和,检错并纠错。难度很高。
  • 添加额外的控制消息。无法从根本上解决问题。因为这个额外的控制消息在传输过程中仍然可能会坏掉。
  • 如果ACK/NAK坏掉,发送方重传。这是普遍使用的方法。但是这样可能会产生重复分组。所以需要采用一种机制解决分组重复的问题。

那怎么解决重复分组的问题?采用常用的解决方法:发送方给每个分组增加序列号。如果是重复的就丢弃。

所以Rdt2.1中解决了ACK/NAK被破坏的问题。

发送方的状态机状态变多了一倍:

在这里插入图片描述

接收方的状态机状态也多了一倍:

在这里插入图片描述

相比于Rdt2.0,Rdt2.1有了这些改进:

  • 发送方:

    • 为每个分组增加了序列号,并且只要两个序列号(0, 1)就够用了
    • 需校验ACK/NAK消息是否发生错误
    • 状态数量翻倍,因为状态必须“记住” “当前”的分组序列号
  • 接收方:

    • 需判断分组是否是重复
    • 注意:接收方无法知道ACK/NAK 是否被发送方正确收到

Rdt2.2:无NAK消息协议

我们真的需要两种确认消息(ACK + NAK)吗?
我们可以定义一种没有NAK消息的协议。

  • 与rdt 2.1功能相同,但是只使用ACK
  • 如何实现?
    • 接收方通过ACK告知最后一个被正确接收的分组
    • 在ACK消息中显式地加入被确认分组的序列号
    • 发送方收到重复ACK之后,采取与收到NAK消息相同的动作,也就是重传当前分组。

Rdt3.0

在Rdt2.0系列我们假设信道只可能发生位错误,那如果可可能丢失分组,怎么办?

“校验和 + 序列号 + ACK + 重传”不够用了。

处理的方法比较简单:发送方等待一个合理的时间

  • 等待了一个合理的时间之后如果没收到ACK,就重传
  • 需要定时器

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

但是停-等操作这个机制让Rdt协议的性能很差。还需要改进。这需要打破停-等协议。

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

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

相关文章

2023年10月随笔之婚宴趣事多

1. 回头看 日更坚持了304天。 读《高性能MySQL(第4版)》更新完成 学信息系统项目管理师第4版系列主体部分更新完成,仅余结语预计11月5日后更新 读《图数据库实战》开更 10月码字125384字,日均码字数4044字,累计码…

如何创建 SpringBoot 多模块项目

1. 创建父模块 【添加依赖】 【删除父模块资源】 父模块只需要保留 pom.xml,其他文件的全部删除(包括 src) 2. 创建子模块 3. 修改父模块 3.1 删除不必要的依赖 3.2 添加打包类型 3.3 添加所有子模块 声明子模块有两个好处: …

LeetCode136——只出现一次的数字

LeetCode136——只出现一次的数字 给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。 你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。 R…

面试官:Nacos有几种负载均衡策略?

作者 | 磊哥 来源 | Java中文社群(ID:javacn666) 转载请联系授权(微信ID:GG_Stone) Nacos 作为目前主流的微服务中间件,包含了两个顶级的微服务功能:配置中心和注册中心。 1.配置中心…

10月第4周榜单丨飞瓜数据B站UP主排行榜榜单(B站平台)发布!

飞瓜轻数发布2023年10月23日-10月29日飞瓜数据UP主排行榜(B站平台),通过充电数、涨粉数、成长指数、带货数据等维度来体现UP主账号成长的情况,为用户提供B站号综合价值的数据参考,根据UP主成长情况用户能够快速找到运营…

【数智化案例展】某国有电力企业——看电力公司如何做好数据资产高效管理,赋能业务决策...

‍ 逸迅科技案例 本项目案例由逸迅科技投递并参与数据猿与上海大数据联盟联合推出的《2023中国数智化转型升级创新服务企业》榜单/奖项”评选。 ‍数据智能产业创新服务媒体 ——聚焦数智 改变商业 2020年8月25日,国资委办公厅颁布《关于加快推进国有企业数字化转型…

SpringBoot概要简介SpringBoot入门,pom文件剖析,打jar包以及banner的修改(附banner生成网址)

SpringBoot概要 SpringBoot介绍 随着动态语言的流行(Ruby、Scala、Node.js), Java的开发显得格外的笨重;繁多的配置、低下的开发效率、复杂的部署流程以及第三方技术整合难度大。 在上述环境下,Spring Boot由此诞生&#xff0c…

C++前缀和算法的应用:统计上升四元组

C前缀和算法的应用:统计上升四元组 本文涉及的基础知识点 C算法:前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 题目 给你一个长度为 n 下标从 0 开始的整数数组 nums ,它包含 1 到 n 的所有数字,请你返回上…

基于松鼠算法的无人机航迹规划-附代码

基于松鼠算法的无人机航迹规划 文章目录 基于松鼠算法的无人机航迹规划1.松鼠搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要:本文主要介绍利用松鼠算法来优化无人机航迹规划。 1.松鼠搜索算法 …

EasyRecovery16优秀的电脑数据恢复软件

你是不是也有过这样的经历,当需要一个文件的时候,却发现不小心被删除了;或者在某个瞬间身体像不受大脑控制般,按下删除或格式化键。气的半夜都能从床上爬起来抽自己一巴掌,反正我是这样的。 我从小到大不小心删除和格…

PowerToys使用:Windows自定义键盘(非编程)

使用紧凑型键盘或者苹果键盘有时候觉得挺麻烦,常用的键偏偏没有,特别是苹果键盘,没有【del】键,非常非常不爽。 笔记本电脑用久了,难免弄坏一两个键,比如【s】键,维修挺麻烦的,换新太…

第五章 子图的绘制及坐标轴共享

第五章 子图的绘制及坐标轴共享 1.绘制固定区域的子图 ​ matplotlib可以将整个画布规划成等分布局的mn(行列)的矩阵区域,并按照先行后列的方式对每个区域进行编号(编号从1开始),之后在选中的某个或某些区…

在图表中添加图例plt.legend()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 在图表中添加图例 plt.legend() plt.legend的作用是? import matplotlib.pyplot as plt x [1, 2, 3, 4, 5] y1 [1, 2, 4, 8, 16] y2 [1, 3, 9, 27, 81] fig, (ax1, ax2) plt.sub…

Mysql系列-索引类型

一 、索引类型别 根据叶子节点的内容分类的索引类型 InnoDB 使用B tree 索引模型,根据叶子节点是否存储数(根据叶子节点的内容)分为主键索引和非主键索引;非主键索引包括:普通索引、唯一索引、组合索引主键索引的叶子…

sql-50练习题16-20

sql-50练习题16-20 前言数据库表结构介绍学生表课程表成绩表教师表 1-6 检索"01"课程分数小于60,按分数降序排列的学生信息1-7 按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩1-8 查询各科成绩最高分、最低分和平均分:以如下形式…

上海亚商投顾:三大指数小幅调整,医药股继续活跃

上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 市场情绪 沪指昨日弱势震荡,尾盘探底回升一度翻红,深成指盘中跌超1%,午后跌幅有所收窄。…

最优值函数二

一、扫地机器人的示例 我们可以明确给出扫地机器人的Bellman最优方程。为了使问题更简洁,我们将状态高和低以及动作搜索、等待和充电分别缩写为h、l、s、w和re。由于只有两个状态,Bellman最优方程由两个方程组成。v∗(h)的方程可以写成: 按照…

飞鼠异地组网工具全网互通实战指南

飞鼠异地组网工具全网互通实战指南 一、飞鼠异地组网工具介绍1.1 飞鼠工具简介1.2 飞鼠工具官网 二、本次实践介绍2.1 本次实践前提2.2 本次实践简介2.3 本次实践环境规划 三、异地组网配置3.1 进入中心控制器节点管理后台3.2 网卡设置3.3 进入子网节点管理后台3.4 网卡设置 四…

EasyExcel动态复杂表头导出设置方法

目录 需求分析解决方案数据问题 需求分析 公司数据比较特殊有一部分数据需要动态修改导致信息导入时表头是不确定的,但其中又有一部分表头是固定的,如下图所示,如果表头全部是固定的话可以通过EasyExcel实体类的注解很轻松的解决&#xff0c…

解决CSS中height:100%失效的问题

出现BUG的场景,点击退出到登录页面,发现高度不对 上面出现了一种只是占了内容的高度,没有占满100%,为什么会出现这种情况呐? 让div的height"100%",执行网页时,css先执行到&#xff0…