计算机网络学习9:可靠传输

简介: 如果提供不可靠传输,丢弃有误码的帧即可,其他不做。如果提供可靠传输服务,就需要告诉发送端重发。

188cae1bd172c654d4f6f3f353b3175b_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

如果提供不可靠传输,丢弃有误码的帧即可,其他不做。

如果提供可靠传输服务,就需要告诉发送端重发。


可靠传输的实现比较复杂。即如果接收端发送给发送端的通知帧(告诉有收到误码)也出现了误码,那该怎么办呢。

de905e958c16b6f27349f5e40d12eead_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

1bc34aba129198ae23dc372eb715dfcd_761fc176126f42b7ad6b68ca17d08026.png

注意,此处将 帧 的称呼 改为了 分组。

6ecdfb14dfecd3b00fe47c23fb6b4514_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

f3e9fa38542980ed9ecc035b1cde24f6_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

4c026917c42d0636c7a6a80d257da78e_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

停止-等待协议 SW


1fa35fdcc1d921a5ef65254af6591621_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_9,color_FFFFFF,t_70,g_se,x_16.png


发送方发送完分组之后,不能立马从缓存中把分组删除,而是要等到ack才能删除。

这样就实现了可靠传输,但是还是会有一些特殊情况。


如果一开始就没发送失败。

838e62a5553424a6ca5d800576762604_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


也有可能就是接收方 发送的确认分组或者否认分组都没有发送出去。


7279f08217108da173875a9bacb6253e_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_15,color_FFFFFF,t_70,g_se,x_16.png

5a5f702a63eed26a750a1ccc42162172_3004a70ab08944348e96d50e7a532572.png


所以需要对确认分组也需要加一个序号。

baf8630568e2443d4bebc58929ec1c57_424f90a2931f47f4ad5fb462abc2c1fa.png


对于点对点,可以不用给确认分组进行编号。数据链路层一般不会出现ACK分组迟到的问题。

6e2a530cfbd0a901657b8b3f7cf8dc65_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

da464ceda223e10daa9c681d89ef442b_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

一般 TA远小于TD,可以 忽略不计。

9d4c6d1eda68bdb5b517db2587fb21af_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

accfdd9f79c1069139794d3382e40acc_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_14,color_FFFFFF,t_70,g_se,x_16.png

例如使用卫星电路,会造成利用率很低。

d4d12f9f1519dff44f82ab2e9da815f2_c06832e0f8a547cf95f6e814c8ad90f7.png

练习题:

a5231355e7fc9e724f255fc3f1538f1e_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

退回N帧协议GBN:Go-Back-N

c27b190a32cfa9312f2aba493233d2e2_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


GBN就是在流水线传输的基础上 利用发送窗口来限制发送方可以连续发送分组的个数

cae34688a89b00da4236368eef79a6ab_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


WT是 发送窗口的范围,如果WT=1 那么就是停止等待协议SW。


如果超过了上限,就会造成严重的错误。

568fdbc6778e002cdbc17d20714bcb36_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


无差错情况:

将0-4号依次发送出去,没有出现乱序和误码,然后按序接收,然后接收窗口向下滑动。发送方接收一个ack,就向前移动一个位置,这样就可以删除发送过的缓存了。

d42cfccc54e081a22b00883541e2b284_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


可以进行进一步的优化,就是累计确认。

0fb3576e36dd909d875e256ebc24d1e7_9f4cc1e1550846dda01ccea972c8496b.png

246b99297d2ca919df2f1e74b18f798b_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

假设ack1传输丢失了,发送方也会知道ack4之前的也正确接收了。发送窗口往前滑动5个位置。接收方可以将已经接收的数据交付给上层处理了。


优点:确认分组丢失,发送方也可以不必重传。还可以减少网络资源的占用。


缺点:不能及时反映正确接收的信息。

f1a309c79e0270381036ba2983cfc23d_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

如果发送56701,而接收方第一个5就已经有差错了,不接收,那么后面的也同样不会接受。将他们丢失,并且重新发送一个ack4。每丢弃一个分组,就会发送一个ack4.


当发送方接收到了重复的ack4后,就可以立刻重传了。

1d11ae0f5c04479b226c04e5bbd4f36d_22e96fa8f97c4804b481f72bb33c7026.png

eaabfddd267b76dc582e3ffa730560d5_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


如果WT超过范围,(成功接收到的信息没有发到发送方。)就会造成接收方无法辨析是不是接受过。

0e9808a36869021c87b3d2a6c90aa139_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


f20f6778ca7f7c05a7239054605b32f9_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

a09e8622c6b6b1a5df260375abd64c87_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

退回N帧协议在流水线传输的基础上利用发送窗口来限制发送方连续发送数据分组的数量,是一种连续ARQ协议。


在协议的工作过程中发送窗口和接收窗口不断的向前滑动,因此这类协议又称为滑动窗口协议。


由于其特性,当通信线路的质量不好时,信道利用率并不比停止-等待协议高。


选择重传协议-SR:selective request

回顾GBN的优缺点:

437d026374e3abf55271bb966dba4dcc_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

选择重传协议为了使得发送方仅仅重传出现差错的分组,接收方不能再采用累积确认!而需要对每个正确接收到数据分组进行逐一确认!

假设采用三个比特来给分组编序号,就是0-7。

32093af11edd4b3d1586af26efac6472_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


f3ff23466f2c0b137a90e516877ca1bf_2d151eacc639426884f5cd25f550fc1a.png

发送方接收到了3之后,并不能使发送窗口向前滑动,因为是未按序到达的窗口。


接收方在没收到2号,那么就接收窗口就不会向前滑动的。


如果在上述过程中,发送方的重传计时器超时了,那么就会重传2号,同时发送方也会记录45号已经成功发送了。

6acb2e58eeab33124da1e57898e33fda_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_11,color_FFFFFF,t_70,g_se,x_16.png


这个时候接收窗口重新收到了2,那么就会往前移动4个。

发送窗口接收到了2,也会向前移动4个。

e0845748f362060855502d8f0ed367cd_0e23bf0f0c1340d8b5647599ce719da5.png


如果超过了窗口的尺寸范围会怎么样呢?


会一样出现接收方无法分辨新旧的数据分组。

c10384e700bdeeec1190f2175a653f98_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png

01d5a82dc8cb670730b43ab68bdc24f6_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5rSy55qE5a2m5Lmg56yU6K6w,size_20,color_FFFFFF,t_70,g_se,x_16.png


相关文章
|
2月前
|
安全 搜索推荐 网络安全
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
75 11
|
2月前
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
120 3
|
2月前
|
网络协议 算法 网络性能优化
计算机网络常见面试题(一):TCP/IP五层模型、TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议
计算机网络常见面试题(一):TCP/IP五层模型、应用层常见的协议、TCP与UDP的区别,TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议、ARP协议
|
4月前
|
监控 网络协议 Linux
网络学习
网络学习
156 68
|
2月前
|
编解码 安全 Linux
网络空间安全之一个WH的超前沿全栈技术深入学习之路(10-2):保姆级别教会你如何搭建白帽黑客渗透测试系统环境Kali——Liinux-Debian:就怕你学成黑客啦!)作者——LJS
保姆级别教会你如何搭建白帽黑客渗透测试系统环境Kali以及常见的报错及对应解决方案、常用Kali功能简便化以及详解如何具体实现
|
2月前
|
安全 网络协议 算法
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-1):主动信息收集之ping、Nmap 就怕你学成黑客啦!
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-1):主动信息收集之ping、Nmap 就怕你学成黑客啦!
|
2月前
|
网络协议 安全 NoSQL
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-2):scapy 定制 ARP 协议 、使用 nmap 进行僵尸扫描-实战演练、就怕你学成黑客啦!
scapy 定制 ARP 协议 、使用 nmap 进行僵尸扫描-实战演练等具体操作详解步骤;精典图示举例说明、注意点及常见报错问题所对应的解决方法IKUN和I原们你这要是学不会我直接退出江湖;好吧!!!
网络空间安全之一个WH的超前沿全栈技术深入学习之路(8-2):scapy 定制 ARP 协议 、使用 nmap 进行僵尸扫描-实战演练、就怕你学成黑客啦!
|
2月前
|
网络协议 安全 算法
网络空间安全之一个WH的超前沿全栈技术深入学习之路(9):WireShark 简介和抓包原理及实战过程一条龙全线分析——就怕你学成黑客啦!
实战:WireShark 抓包及快速定位数据包技巧、使用 WireShark 对常用协议抓包并分析原理 、WireShark 抓包解决服务器被黑上不了网等具体操作详解步骤;精典图示举例说明、注意点及常见报错问题所对应的解决方法IKUN和I原们你这要是学不会我直接退出江湖;好吧!!!
网络空间安全之一个WH的超前沿全栈技术深入学习之路(9):WireShark 简介和抓包原理及实战过程一条龙全线分析——就怕你学成黑客啦!
|
3月前
|
存储 安全 网络安全
浅谈网络安全的认识与学习规划
浅谈网络安全的认识与学习规划
50 6

热门文章

最新文章