zoukankan      html  css  js  c++  java
  • 【计算计网络】可靠数据传输原理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

    每天进步一点点,不要停止前进的脚步~
  • 相关阅读:
    BT5启动SSH服务
    RIP路由协议的水平分割和触发更新
    FATFS Copy Files
    spi master vhd
    altera cpld spi master verilog
    SPI bus master for System09
    How To Set a Status Flag in One Clock Domain, Clear It in Another
    VHDL 整数 小数 分数 分频
    vhdl 状态机
    The DualModulus Divider in VHDL
  • 原文地址:https://www.cnblogs.com/myworld7/p/8353515.html
Copyright © 2011-2022 走看看