可靠数据传输原理1(构造可靠数据传输协议)-程序员宅基地

技术标签: 网络  

TCP向调用它的因特网应用所提供的服务模型(服务抽象)

数据可以通过一条可靠的信道进行传输。借助于可靠的信道,传输比特就不会受到损坏或丢失,而且所有数据都是按其发送顺序进行交付。

可靠传输协议

实现服务模型就需要可靠的传输协议。但是由于可靠传输协议的下层协议可能是不可靠的,所以可靠传输协议的实现比较复杂。

构造可靠传输协议

1. 经完全可靠信道的可靠数据传输:rdt 1.0

  先是考虑最简单的情况,底层信道是完全可靠的。因为信道是完全可靠的,所以发送方传输给接收方的数据会没有比特差错,接收方也不必向发送方提供任何反馈信息。

2. 经具有比特差错信道的可靠数据传输:rdt 2.0

  在实际底层信道中传输的分组中的比特可能会受损。在分组的传输、传播或者缓存的过程中,这种比特差错常发生在网络的物理部件中。现在我们继续假定所有发送的分组(某些比特会受损)将按其发送顺序被接收。
  接收方接收到发送方的分组后,需要告知之发送方自己收到的分组是正确的、还是有比特错误的(发送发就会重传该分组)。基于这样的传重传机制的可靠传输协议称为自动重传请求(Automatic Repeat reQuest ARQ)协议

  在ARQ协议中需要三种协议功能来处理比特差错

  • 差错检测
    差错检测机制使得接收方能够检测到分组中出现了比特差错。
    例如:UDP中的检验和字段是一种差错检测机制,在数据连路层会使用CRC循环冗余检测机制进行差错检测。

  • 接收方反馈
    因为发送方和接收方通常在不同端系统上执行,发送方要了解接收方的情况(分组是否被正确接收)的唯一途径就是让接收方提供明确的反馈消息给发送方。
    rdt2.0协议将从接收方向发送方回送ACK或者NAK分组。理论上分组只需一个比特长,如0表示NAK,1表示ACK。

  • 重传
    接收收到有差错的分组时,发送方将重传该分组。

  需要注意:当发送发处于等待ACK或者NAK的状态时,它不能从上层获得更多的数据。也就是说发送方不会发送一块新的数据,除非发送方确信接收方已正确接收当前分组。此时的rdt 2.0被称为停止等待(stop-and-wait)协议

  协议rdt2.0看起来虽然可以运行了,但是有一个致命的缺陷,没有考虑到ACK/NAK分组受损的可能性!

  通常解决受含糊不清的ACK/NAK时,发送方会重传当前数据分组。
这样会让接收方的信道中出现冗余分组
  解决冗余分组的方法是在数据分组中添加一新字段,让发送方对其数据分组进行编号,将分组的编号填入该字段中。接收方只需要检查序号就可以得知该分组是否是一次重传。
  对于停止等待协议来说,1比特序号就可以了,重传的分组序号与最近接收到的分组序号相同,新的分组序号会变化(使用模2使序号前移)。目前我们假定的是信道不会丢失分组,所以ACK/NAK分组本身不需要指明他们要确认的分组序号。发送方接收到ACK/NAK分组是为响应最近发送的数据分组而生成的。

  rdt2.1反映出目前正在发送的分组或希望接收的分组的序号是0还是1。
  rdt2.1使用了从接收方收到的肯定确认和否定确认。当接收方收到失序分组时,发送肯定确认。如果收到受损分组,则发送否定确认。
  如果不发送NAK,而是对正确接收到的分组发送一个ACK,那么也能得到与NAK一样的效果。发送方收到对同一个分组的两个ACK(接收到了冗余ACK)后,就可以知道接收方没有正确接收被确认两次的分组后面的分组。
  这也产生了协议rdt2.2。rdt2.2是在有比特差错信道上实现的一个无NAK的可靠传输协议,此时ACK报文就需明确所确认的分组序号。

3. 经具有比特差错的丢包信道的可靠传输:rdt3.0(比特交替协议)

  在今天的计算机网络中除了比特会出现受损也会出现丢包的情况。所以,现在协议需要关注两个问题:怎样检测丢包以及丢包后该做些什么。
  有很多方法用于解决丢包问题。这里,我们让发送方负责检测和恢复丢包工作。接收方确实没有接收到数据分组和接收方响应给发送方的ACK丢失,都会让发送发收不到接收方的响应。发送方等待足够长的时间来确认分组丢失,然后进行重传分组。如果是因为ACK丢失,发送方重传分组则会造成冗余数据分组。但是,rdt2.2中的序号可以解决接收方收到冗余分组的问题。
  在发送方的眼里,重传是一种万能灵药。无论数据分组丢失还是ACK丢失都可以采用同样的动作:重传。基于时间的重传机制,需要一个倒计时定时器,在一个给定的时间量过期后,可中断发送方。因此,发送方需要做到 ① 每次发送一个分组(包括第一次和重传分组)时,便启动一个定时器 ② 响应定时器中 断 ③ 终止定时器

  归纳:在构造可靠传输协议的过程中我们用到了检验和、序号、定时器、肯定和否定确认分组技术。


此文为《计算机网络 自顶向下方法》学习笔记1

转载于:https://www.cnblogs.com/myworld7/p/8353515.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_30236595/article/details/99574713

智能推荐

网络安全笔记_安全知识笔记-程序员宅基地

文章浏览阅读4.4k次,点赞9次,收藏69次。课程路径:华南理工大学公开课:网络安全网络安全将是未来的基石,万物互联的基础保障。第一节 现状分析病毒,变种病毒;漏洞攻击,技术人员的后门导致;假网址;中断,截获,篡改,伪造被动攻击和主动攻击安全服务:保密,认证,完整,不可否认安全框架:安全攻击,安全服务,安全机制第二节 常规加密技术公钥密码学加密操作类型:代换,置换,多重加密单密钥算法和多密钥算法对称加密:发送..._安全知识笔记

js判断日期合法性_js判断日期是否合法-程序员宅基地

文章浏览阅读3.2k次,点赞4次,收藏6次。functioncheck(date){ return(newDate(date).getDate()==date.substring(date.length-2)); } //参数date可以格式化为xx-xx-xx或xxxx-xx-xx或用/分割 附:通常来说,javascript验证日期的有效性可以通过正则判断但正则表达式无法精准验证日期的有效性,你无法通过正则表达式判断出1900-02-29是非法日期而2000-02-29是合法日期,..._js判断日期是否合法

matlab调用c,mex的 mexw64 不是有效的 Win32 应用程序-程序员宅基地

文章浏览阅读1.2k次。使用OpenCV库,进行混合编程时mex.c文件能够编译成功,并且生出mexw64文件: 但是在调用编程成功的函数时,提示下面的错误: 解决方法: 将系统环境变量中的OpenCV bin目录进行如下的修改。 将x86修改为x64,即:C:\OpenCV2.4\build\x86\vc10\bin;修改为:C:\OpenCV2.4\build\x64\..._mex 文件 'resize.mexw64' 无效: opencv

STL中迭代器的实现_stl迭代器实现-程序员宅基地

文章浏览阅读1.8w次,点赞6次,收藏21次。 STL中迭代器的实现junguo 最近在看候捷先生的《STL源码剖析》,侯先生写的挺好的。但我读起来总感觉有些拗,理解起来有些费劲,可能他看问题的观点和我不一样造成的。开始的时候总是不太理解,后来理顺了自己的思路,发现有些东西其实并不难。在此把我对迭代器的理解整理一下,也是帮助自己消化一下,因为我发现不动手,很多东西容易遗忘。 文章里提供的一些例子程序是在D_stl迭代器实现

14、详解java同步工具类CountDownLatch_java coundlash-程序员宅基地

文章浏览阅读2k次,点赞5次,收藏37次。这篇文章主要讲解java中一个比较常用的同步工具类CountDownLatch,不管是在工作还是面试中都比较常见。我们将通过案例来进行讲解分析。一、定义CountDownLatch的作用很简单,就是一个或者一组线程在开始执行操作之前,必须要等到其他线程执行完才可以。我们举一个例子来说明,在考试的时候,老师必须要等到所有人交了试卷才可以走。此时老师就相当于等待线程,而学生就好比是执行的线程。注..._java coundlash

顺序性容器(vector&list&deque)_vector list 赋值顺序-程序员宅基地

文章浏览阅读313次。引言(1)vector向量相当于一个数组 在内存中分配一块连续的内存空间进行存储。支持不指定vector大小的存储。STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capacity()函数返回的大小,当超过此分配的空间时再整体重新放分配一块内存存储,这给人以vector可以不指定vector即一个连续内存的大小的感觉。通常此默认的内存分配能完成大部分情况下的存_vector list 赋值顺序

随便推点

【简单】在单链表中删除指定值的节点-Java:解法二_单向链表怎么删除指定节点数据-程序员宅基地

文章浏览阅读905次。package live.every.day.ProgrammingDesign.CodingInterviewGuide.List;/** * 在单链表中删除指定值的节点 * * 【题目】 * 给定一个链表的头节点head和一个整数num,请实现函数将值为num的节点全部删除。 * * 【难度】 * 简单 * * 【解答】 * 方法二:不用任何容器而直接调整的方法。时间复杂度为O(N),额外空间复杂度为O(1)。 * * 首先从链表头开始,找到第一个值不等于num的节点,作为新_单向链表怎么删除指定节点数据

python求解整数规划_如何用python结合cplex求解混合整数规划问题-程序员宅基地

文章浏览阅读1.4k次。第一步:注册IBM id账号第二步:下载相关系统的CPLEX(windows/linux/mac)这里需要系统中安装有JAVA,选择 open with Java web start launcher (需要下载JAVA),打开后就开始进入下载页面。补充JAVA安装:备注:JAVA可以通过rpm包安装,或者是bin文件安装。Rpm安装可以直接双击就可以打开jnlp后缀的文件,bin文件安装的话,需..._cplex求解双目标混合整数规划模型

CentOS 7.X 源码编译安装MariaDB-10.2.X_group ‘mail’ not found-程序员宅基地

文章浏览阅读2.5k次。CentOS 7 编译安装MariaDB-10.2.XCentOS 7下mariadb-10.1.22 源码编译安装过程笔记,希望对大家有帮助。 下载文件https://mariadb.com/ 或 https://downloads.mariadb.org/mariadb/10.2.11/
源码包的下载下载链接: https://mirrors.tuna.tsinghua.edu.cn/m_group ‘mail’ not found

wps中的大客户版本_wps 大客户版-程序员宅基地

文章浏览阅读462次,点赞11次,收藏8次。网上的WPS各个版本基本都带有稻香插件,广告一堆堆,用户需要注册才能减少广告的显示,但依然时不时跳出来显示。其实WPS给大学做过一些版本,这种定制版本应用于大学院系的文档编写使用。最关键的是这个版本没有广告,没有稻香,没有推荐模板,只有纯净的WPS。界面虽然不华丽,风格还是很传统office2000风格,不是烦人的多标签页,也不会隐藏。工具栏不会藏着掖着直接横排展示所有图标,鼠标不用切换页,所有工具一目了然。这集美大学版本是办公软件的不二之选。_wps 大客户版

Android自动化页面测速在美团的实践-程序员宅基地

文章浏览阅读587次,点赞8次,收藏19次。我们都知道ViewPager的Tab切换是可以通过一个 OnPageChangeListener 对象进行监听的,所以我们可以为ViewPager添加一个自定义的Listener对象,在切换时记录一个时间,这样可以通过用这个时间减去页面创建后的时间得出这个多余的等待时间,上报时在总时间中减去即可。这里的 getConfigModel() 方法中,会使用页面的类名或者全路径类名,去初始化时解析的配置Map中进行id的匹配,如果匹配到说明页面需要测速,就会创建测速对象 PageObject 进行测速。

百度竞价悄然改版-程序员宅基地

文章浏览阅读42次。前段时间百度因为“魏则西事件”而被要求整改,百度的竞价排名也被推向了风口浪尖。最近有网友@闪电精灵SEO张扬爆料:百度竞价已改版,竞价显示4条,或许取消了右侧排名! 但是在经过风波之后,百度的确有了一些变化,最明显的变化就是对推广的网站的标注,之前的对百度推广只有推广两个字,现在是成了蓝色..._python 百度竞价排名