【可靠数据传输的原理】

文章目录

  • 可靠数据传输的原理
    • 可靠数据传输(rdt)的原理
    • 可靠数据传输:问题描述
    • Rdt1.0: 在可靠信道上的可靠数据传输
    • Rdt2.0:具有比特差错的信道
    • rdt2.0:FSM描述
    • rdt2.0:没有差错时的操作
    • rdt2.0:有差错时
    • rdt2.0的致命缺陷!-> rdt2.1
    • rdt2.1:讨论
    • rdt2.2:无NAK的协议
    • rdt3.0:具有比特差错和分组丢失的信道

可靠数据传输的原理

可靠数据传输(rdt)的原理

  • rdt在应用层、传输层和数据链路层都很重要
  • 网络Top 10问题之一
  • 信道的不可靠特点决定了可靠数据传输协议( rdt )的复杂

可靠数据传输:问题描述

rdt_send(): 被上层(如应用层)调用,以将数据交付给下方发送实体
udt_send(): 被rdt调用,用以将分组放到不可靠的信道上传输到接收方
udt_rcv(): 当分组通过信道到达接收方时被调用
deliver_data(): 被rdt调用,将数据交付给上层

Rdt1.0: 在可靠信道上的可靠数据传输

  • 下层的信道是完全可靠的
    • 没有比特出错
    • 没有分组丢失
  • 发送方和接收方的FSM
    • 发送方将数据发送到下层信道
    • 接收方从下层信道接收数据
      在这里插入图片描述

Rdt2.0:具有比特差错的信道

  • 下层信道可能会出错:将分组中的比特翻转
    • 用校验和来检测比特差错
  • 问题:怎样从差错中恢复:
    • 确认(ACK):接收方显式地告诉发送方分组已被正确接收
    • 否定确认( NAK): 接收方显式地告诉发送方分组发生了差错
      • 发送方收到NAK后,发送方重传分组
  • rdt2.0中的新机制:采用差错控制编码进行差错检测
    • 发送方差错控制编码、缓存
    • 接收方使用编码检错
    • 接收方的反馈:控制报文(ACK,NAK):接收方->发送方
    • 发送方收到反馈相应的动作

rdt2.0:FSM描述

在这里插入图片描述

rdt2.0:没有差错时的操作

在这里插入图片描述

rdt2.0:有差错时

在这里插入图片描述

rdt2.0的致命缺陷!-> rdt2.1

如果ACK/NAK出错?

  • 发送方不知道接收方发生了什么事情!
  • 发送方如何做?
    • 重传?可能重复
    • 不重传?可能死锁(或出错)
  • 需要引入新的机制
    • 序号
      处理重复:
  • 发送方在每个分组中加入序号
  • 如果ACK/NAK出错,发送方重传当前分组
  • 接收方丢弃(不发给上层)重复分组
    在这里插入图片描述

rdt2.1:讨论

发送方:

  • 在分组中加入序列号
  • 两个序列号(0,1)就足够了
    • 一次只发送一个未经确认的分组
  • 必须检测ACK/NAK是否出错(需要EDC )
  • 状态数变成了两倍
    • 必须记住当前分组的序列号为0还是1
      接收方:
  • 必须检测接收到的分组是否是重复的
    • 状态会指示希望接收到的分组的序号为0还是1
  • 注意:接收方并不知道发送方是否正确收到了其ACK/NAK
    • 没有安排确认的确认
      在这里插入图片描述
      接收方不知道它最后发送的ACK/NAK是否被正确地收到
  • 发送方不对收到的ack/nak给确认,没有所谓的确认
  • 接收方发送ack,如果后面接收方收到的是:
    • 老分组p0?则ack 错误
    • 下一个分组?P1,ack正确

rdt2.2:无NAK的协议

  • 功能同rdt2.1,但只使用ACK(ack 要编号)
  • 接收方对最后正确接收的分组发ACK,以替代NAK
    • 接收方必须显式地包含被正确接收分组的序号
  • 当收到重复的ACK(如:再次收到ack0)时,发送方与收到NAK采取相同的动作:重传当前分组
  • 为后面的一次发送多个数据单位做一个准备
    • 一次能够发送多个
    • 每一个的应答都有:ACK,NACK;麻烦
    • 使用对前一个数据单位的ACK,代替本数据单位的nak
    • 确认信息减少一半,协议处理简单
      在这里插入图片描述

rdt3.0:具有比特差错和分组丢失的信道

新的假设:下层信道可能会丢失分组(数据或ACK)

  • 会死锁
  • 机制还不够处理这种状况:
    • 检验和
    • 序列号
    • ACK
    • 重传
      方法:发送方等待ACK一段合理的时间
  • 发送端超时重传:如果到时没有收到ACK->重传
  • 问题:如果分组(或ACK )只是被延迟了:
    • 重传将会导致数据重复,但利用序列号已经可以处理这个问题
    • 接收方必须指明被正确接收的序列号
    • 需要一个倒计数定时器
      链路层的timeout时间确定的传输层timeout时间是适应式的

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

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

相关文章

数图可视化品类空间管理系统入编《零售门店数字化赋能专项报告(2024年)》

数图可视化品类空间管理系统荣幸入编中国连锁经营协会发布的 《零售门店数字化赋能专项报告(2024年)》,报告以零售门店为切入点,通过引入“5P”的技术框架及梳理业内配套最佳实践方案,理出一套科学的、完整的零售门店数…

内存管理(C/C++)

✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅✅ ✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨✨ 🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿🌿&#x1…

所有图片按照固定数量保存到新建文件夹

一、需求 有很多图片在不同的文件夹中,将所有图片汇集起来,按照固定的数量保存到新建的文件夹中 二、代码: import os import shutil import glob# 图片文件夹路径 file_path r"E:\tu_ret"# 指定目标根目录 dst_root_dir r&qu…

C语言转型之路:从C到C++的类与对象初探

欢迎来CILMY23的博客 本篇主题为 C语言转型之路:从C到C的类与对象初探 个人主页:CILMY23-CSDN博客 个人专栏系列: Python | C语言 | 数据结构与算法 | C 感谢观看,支持的可以给个一键三连,点赞关注收藏。 写在前头…

蜂窝物联:蜂窝云平台全介绍

蜂窝云平台 PART 01 PC端展示平台 GIS地图 将地块嵌入到GIS地图展示,可以清晰展示各个地块所在地里位置,可以点击各个地块,在该界面可以清晰查看所选择地块的设备数据、监控画面、设备开关控制、基地介绍、基地图片等信息。 界面支持个化…

企业会议简单要求

会议原则: * 能不开会就不开会,根据开会目的与目标来确定 * 分清自己的角色,做好会前准备和会议引导会议过程: 1. 会前准备 会议召集人会前准备工作: * why:开会是否能解决问题,是否需要开会* 需要多人&…

【35分钟掌握金融风控策略8】策略评审

目录 策略自动化开发系统 策略评审 策略评审流程 档案管理 策略评审文档设计和撰写 策略自动化开发系统 当前,金融机构大多注重提升金融风控相关的科技实力,希望依托科技降低风控门槛,提高风控效率,降低风控成本。 单维度策…

快速掌握缓存技术:学习多个缓存供应商(ehcache,redis,memcached,jetcache,j2cache)

缓存技术 缓存模拟缓存Spring缓存技术第三方缓存技术Ehcache缓存供应Redis缓存memcached缓存(国内) jetcache缓存供应商jetcache的基本使用设置外部服务设置本地服务 jetcache方法缓存j2cache 缓存 什么是缓存 缓存是一种介于数据永久存储介质与数据应用…

Spring的循环依赖问题如何解决

1 构造器注入:通过构造器注入可以避免循环依赖的问题。当两个或多个Bean之间存在循环依赖时,将依赖通过构造函数参数传递,这样Spring容器在创建Bean实例时就可以通过构造函数解决循环依赖。 2 Setter注入:与构造器注入类似&#x…

c++中什么叫做窄式转换(narrowing conversions)以及窄式转换解决方案

c中什么叫做窄式转换(narrowing conversions)以及窄式转换解决方案 什么叫做窄式转换(narrowing conversions) 窄化转换(narrowing conversion)是指将一个值转换为另一种类型,但转换过程中丢失了信息或超出了目标类型的表示范围的情况。在C…

C++ | Leetcode C++题解之第38题外观数列

题目&#xff1a; 题解&#xff1a; class Solution { public:string countAndSay(int n) {string prev "1";for (int i 2; i < n; i) {string curr "";int start 0;int pos 0;while (pos < prev.size()) {while (pos < prev.size() &&…

【Elasticsearch】Elasticsearch 从入门到精通(一):基本介绍

Elasticsearch 从入门到精通&#xff08;一&#xff09;&#xff1a;基本介绍 1.Elasticsearch2.Elasticsearch 使用案例3.Elasticsearch 对比 Solr4.Elasticsearch 基本概念及架构4.1 Elasticsearch 基本概念4.1.1 索引 index4.1.2 映射 mapping4.1.3 字段 Field4.1.4 类型 Ty…

C 语言实例 - 输出单个字符

使用 printf() 与 %c 格式化输出一个字符。 #include <stdio.h>int main() {char c; // 声明 char 变量c A; // 定义 char 变量printf("c 的值为 %c", c);return 0; }输出结果&#xff1a; c 的值为 A

torch.mm函数介绍

torch.mm() 是 PyTorch 中用于执行矩阵乘法&#xff08;matrix multiplication&#xff09;的函数。它能够将两个给定的张量进行矩阵乘法运算&#xff0c;得到结果张量。 这是 torch.mm() 函数的基本语法&#xff1a; torch.mm(input, mat2, *, outNone)input: 第一个输入张量…

基于SkyEye运行Qt:著名应用程序开发框架

Qt是一个著名的跨平台的C图形用户界面应用程序开发框架&#xff0c;目前包括Qt Creator、Qt Designer等等快速开发工具&#xff0c;还支持2D/3D图形渲染、OpenGL&#xff0c;允许真正的组件编程&#xff0c;是与GTK、MFC、OWL、ATL一样的图形界面库。使用Qt开发的软件可以做到一…

【cygwin】工具安装apt-cyg

目录 下载安装查看是否安装成功安装软件 下载 git clone https://github.com/transcode-open/apt-cyg.git安装 cd apt-cyg mv apt-cyg /usr/local/bin/ 查看是否安装成功 apt-cyg --help安装软件 apt-cyg install nano

C++:模板详解

模板详解 1.函数模板1.概念2.语法3.原理4.实例化1.隐式实例化2.显示实例化 5.匹配原则 2.类模板1.格式2.实例化 3.非类型模板参数注意点 4.特化1.概念2.函数模板特化1.前提2.语法说明3.示例 3.类模板特化1.全特化2.偏特化/半特化3.选择顺序 4.按需实例化 5.模板的分离编译1.分离…

力扣-分隔链表

题目 86. 分隔链表 思路 本来想直接在链表上进行修改&#xff0c;但是发现太乱。 定义两个新的空链表&#xff0c;一个保存小于 x 的节点&#xff0c;另一个保存大于等于 x 的节点。 public ListNode partition (ListNode head, int x){ListNode smallNode new ListNode(0…

lementui el-menu侧边栏占满高度且不超出视口

做了几次老是忘记&#xff0c;这次整理好逻辑做个笔记方便重复利用&#xff1b; 问题&#xff1a;elementui的侧边栏是占不满高度的&#xff1b;但是使用100vh又会超出视口高度不美观&#xff1b; 解决办法&#xff1a; 1.获取到侧边栏底部到视口顶部的距离 2.获取到视口的高…

Java集合面试题2024年4月20记录

一、集合的作用&#xff1f; 集合是可以存储一批类型不同的对象&#xff0c;针对集合的实现类有很多&#xff0c;作用都是一样的&#xff0c;即存储传输数据&#xff0c;但存储的数据结构不一样&#xff0c;其速度、安全性也不一样。 二、集合框架的组成&#xff1f; 1、接口…