计算机网络:数据链路层 - CSMA/CA协议

计算机网络:数据链路层 - CSMA/CA协议

    • CSMA/CA概述
    • 帧间间隔
    • 工作原理
    • 退避算法
    • 虚拟载波监听


CSMA/CA概述

讲解CSMA/CA之前,我们回顾一下CSMA/CD的三个特性:

多址接入MA:多个主机连接在一条总线上,竞争使用总线
载波监听CS:每一个站点在发送帧之前,先要检测一下总线上是否有其他站点在发送帧
碰撞检测CD:每一个正在发送帧的同时,一边发送帧一边检测。一旦发现总线上出现碰撞,则立即停止发送,退避一段随机时间后再次重新发送

CSMA/CD 协议已经解决了有线局域网的传输问题,那么同样使用广播信道的无线局域网能不能也使用 CSMA/CD 协议呢?

在无线局域网中仍然可以使用载波监听CS以及多址接入MA,即在发送帧之前先对传输媒体进行载播监听。若发现有其他站在发送帧,就推迟发送,以避免发生碰撞

但是在无线局域网中不能使用碰撞检测CD,由于无线信道的传输条件特殊,其信号强度的波动范围非常大,无线网卡上接收到的信号强度往往会远远小于发送信号的强度,可能相差百万倍。如果要在无线网卡上实现碰撞检测,对硬件的要求非常高。

另外一个问题,就是隐蔽站问题:

在这里插入图片描述

这里有 4 个无线站点,A 的信号范围可以覆盖到 B,但不能覆盖到 C。C 信号范围可以覆盖到 B,但不能覆盖到 A。换句话说, A 和 C 都检测不到对方的无线信号。当 A 和 C 都要给 B 发送帧时,就会产生碰撞,但 A 和 C 无法检测到碰撞,这种未能检测出信道上其他站点信号的问题叫做隐蔽站问题。

当出了自己的检测范围,就无法识别到碰撞,那么在发送时检测碰撞也是没有有意义的。因此 802.11 无线局域网使用 CSMA/CA 协议在保留CSMA的基础上去掉了CD,也就是实时监测碰撞。增加了一个 CACA是一种避免碰撞的功能。

因此CSMA/CA协议的含义如下:

多址接入MA:多个主机在一个局域网中竞争使用信道
载波监听CS:每一个站点在发送帧之前,先要检测一下是否有其他站点在发送帧
避免碰撞CA:主机发送信号时,尽可能地避免发送碰撞

由于不可能避免所有的碰撞,并且无线信道误码率较高, 802.11 标准还使用了停止等待协议来保证数据被正确接收。


帧间间隔

802.11 标准规定所有的站点必须在持续检测到信道空闲一段指定时间后才能发送帧,这段时间称为帧间间隔 IFS

帧间间隔的长短取决于该站点要发送的帧的类型,高优先级帧需要等待的时间较短,因此可优先获得发送权。低优先级帧需要等待的时间较长,若某个站的低优先级帧还没来得及发送,而其他站的高优先级帧已发送到信道上,则信道变为忙状态,因而低优先级帧就只能在推迟发送了,这样就减少了发生碰撞的机会。

常用的两种帧间间隔如下:

  • 短帧间间隔 SIFS:长度为 28 微秒,是最短的帧间间隔,用来分隔开属于一次对话的各个帧,一个站点应当能够在这段时间内从发送方式切换到接收方式。

  • DCF帧间间隔 DIFS:长度为 128 微秒,它比短帧间间隔 SIFS 要长得多。在 DCF 方式中用来发送数据帧和管理帧。


工作原理

接下来我们来举例说明 CSMA/CA 协议的工作原理

如图所示:

在这里插入图片描述

以上站点都是无线站点,横坐标为时间假设无线信道是空闲的,源站有数据帧要发送,当源站检测到信道空闲,则在等待帧间间隔 DIFS 后发送该数据帧:

在这里插入图片描述

目的站若正确收到该数据帧,则经过帧间间隔 SIFS 后向源站发送确认帧ACK

在这里插入图片描述

需要说明的是,若源站在规定时间内没有收到确认帧ACK ,重传计时器超时后,就必须重传该数据帧,直到收到确认为止,或者经过若干次的重传失败后放弃发送。

源站为什么在检测到信道空闲后还要再等待帧间间隔 DIFS 后才发送数据帧呢?

这就是考虑到可能有其他的站有高优先级的帧要发送,若有就让高优先级帧先发送

目的站又是为什么在正确接收数据帧后,还要再等待一段时间 SIFS 才能发送ACK帧?

SIFS 是最短的帧间间隔,用来分隔开属于一次对话的各个帧。在这段时间内,一个目的站会从发送方式切换到接收方式。

如图所示,在源站和目的站的一次对话过程中,无线信道处于忙状态。若无线信道处于忙状态时,其他无线站点要发送数据,则必须退避
在这里插入图片描述

当信道从忙状态转换到空闲状态并经过帧间间隔 DIFS 后,其他要发送数据的无线站点需要退避一段随机时间后才能发送

既然信道已经由忙转为空闲,且经过帧间间隔 DIFS 后,为什么还要退避一段随机时间才能使用信道,而不是立即使用信道呢?

这样做的目的在于防止多个站点同时发送数据而产生碰撞。

当站点检测到信道是空闲的,并且没有连续发送数据,则不使用推避算法。

而以下情况必须使用退避算法

1.在发送数据帧之前检测到信道处于忙状态时,必须使用退避算法

  • 因为处于忙状态时,就可能会有多个站点准备发送,为了防止忙状态刚结束结束,多个站点同时发送数据,于是利用退避算法,把多个站点的发送交错开。

2. 在每一次重传一个数据帧时,必须使用退避算法
3. 在每一次成功发送后,要连续发送下一个帧时,必须使用退避算法

  • 这是为了避免一个站点长时间占用信道。

退避算法

在CSMA/CA协议中,采用了截断二进制指数退避算法来进行退避操作,以产生随机的数值进行退避,确保主机碰撞后退避的时间不同。

算法如下:

  1. 规定基本退避时间为一个时隙的长度t
  2. 定义参数 k = min(重传次数, 6)
  3. 从整数区间[0, 2 k − 1 2^{k} - 1 2k1]随机选一个数字r,最后的退避时间为 r × 2 τ {\color{Red} r \times 2\tau } r×2τ

接下来我再详细讲解以上算法的执行过程。

首先要设置一个基本的退避时间,该时间被设置为 2 t 2t 2t。而最后的总退避时间,就等于一个随机数r乘以这个基本退避时间 2 t 2t 2t,也就是 r × 2 t {\color{Red} r \times 2t } r×2t

那么现在的问题就是,要如何生成这个随机数r。该随机数r取自一个区间[0, 2 k − 1 2^{k} - 1 2k1],而这个k不是一个固定的数值,其与重传次数相关。

  • 如果重传次数小于6,那么 k 就是重传次数
  • 如果重传此处大于6,那么 k = 6

比如说当前是第2次重传,那么k = 2,r的取值范围就是[0, 2 2 − 1 2^{2} - 1 221],也就是[0, 3]。最后r在这个区间内随机取一个值,最终的退避时间就是 r × 2 t r \times 2t r×2t

再比如当前是第8次重传,由于重传次数超过6,那么k = 6,r的取值范围就是[0, 2 6 − 1 2^{6} - 1 261],也就是[0, 255]。最后r在这个区间内随机取一个值,最终的退避时间就是 r × 2 t r \times 2t r×2t

我们来举例说明。CSMA/CA协议的退避算法如图所示,ABCDE 是 5 个无线站点,横坐标为时间:

在这里插入图片描述

假设 A 正在占用无线信道发送帧,在 A 的发送过程中,B、C、 D 也要发送帧,我们用向上的箭头来表示。于是进行载波监听,发现信道忙,需要退避,根据退避算法选择出一个随机的退避时间,并在每个时期对信道进行一次检测,当检测到信道由盲状态转为空闲状态且经过帧间间隔 DIFS 后,退避计时器开始倒计时

在这里插入图片描述

假设 C 退避时间最短,当 C 退避计时器到时候, C 立即开始发送帧,此时信道由空闲状态转换为忙状态,当 B 和 D 检测到信道忙后,就冻结各自剩余的退避时间

在这里插入图片描述

假设在 C 占用无线信道发送帧的过程中, E 也要发送帧,于是进行载波监听,发现信道忙,需要退避,当检测到信道由盲状态转为空闲状态,经过帧间间隔 DIFS 后,退避计时器开始倒计时:

在这里插入图片描述

B 和 D 退避计时器从上次冻结的退避剩余时间开始。

倒计时 D 的退避计时器会首先到时 D 立即开始发送帧,此时信道由空闲状态转换为忙状态:

在这里插入图片描述

当 B 和 E 检测到信道忙后,就冻结各自剩余的退避时间。

当 D 发送完帧后,信道将转为空闲状态。当 B 和 E 检测到信道由忙状态转换为空闲状态,且经过帧间间隔 DIFS 后,退避计时器重新开始,从上次冻结的退避剩余时间开始倒计时:
在这里插入图片描述

E 的退避计时器结束, E 立即开始发送帧,此时信道由空闲状态转换为忙状态:

在这里插入图片描述

当 B 检测到信道忙后,就冻结自己剩余的退避时间。

当 E 发送完帧后,信道将转为空闲状态。当 B 检测到信道由盲状态转换为空闲状态,且经过帧间间隔 DIFS 后,退避计时器重新开始从上次冻结的退避剩余时间开始倒计时,当 B 的退避计时器到时候, B 立即开始发送帧:

在这里插入图片描述

若 B 发送完这一帧后还有帧要发送,则在检测到信道空闲且经过帧间间隔 DIFS 后,因为是相同的站点连续发送,还必须再退避一段随机时间后才能发送:

在这里插入图片描述


虚拟载波监听

接下来我们介绍CSMA/CA协议的信道预约和虚拟载波监听。

为了尽可能减少碰撞的概率和降低碰撞的影响, 802.11 标准允许要发送数据的站点对信道进行预约。

源站在发送数据帧之前先发送一个短的控制帧,称为请求发送RTS,它包括源地址、目的地址以及这次通信所需的持续时间

如图所示,当源站检测到信道空闲且经过帧间间隔 DIFS 后发送 RTS 帧:
在这里插入图片描述

若目的站点正确收到源站发来的RTS 帧,在检测到信道空前且经过帧间间隔 SIFS 后就发送一个响应控制帧,称为允许发送CTS。它也包括这次通信所需的持续时间:

在这里插入图片描述

源站收到 CTS 帧后再等待一个帧间间隔 SIFS 后,就可发送其数据帧:

在这里插入图片描述

若目的站正确收到了源站发来的数据帧,在等待一个帧间间隔 SIFS 后,就向源站发送确认帧ACK

在这里插入图片描述

如果 RTS 帧发生碰撞,源站就收不到 CTS帧,需要执行退避算法重传RTS 帧。由于 RTS 帧和 CTS 帧很短,发生碰撞的概率、碰撞产生的开销以及本身的开销都很小。而对于一般的数据帧,其发送时延往往大于传播时延,碰撞的概率很大,且一旦发生碰撞而导致数据帧重发,则浪费的时间就很多,因此用很小的代价对信道进行预约往往是值得的

由于利用虚拟载波监听机制,其它站点只需要监听到 RTSCTS数据帧中的任何一个,就能知道信道被占用的持续时间,而不需要真正监听到信道上的信号。因此,虚拟载破监听机制能减少隐蔽站带来的碰撞问题。

除源站和目的站以外的其他各站在收到 CTS 帧或数据帧后就推迟接入到无线局域网中。这样就保证了源站和目的站之间的通信不会受到其他站的干扰

例如,这是 4 个无线站点, A 和 C 互为隐蔽站, A 的信号可以覆盖到 B,但不能覆盖到C。 C 的信号可以覆盖到 B,但不能覆盖到 A:

在这里插入图片描述

A 在给 B 发送数据帧前,可以使用 RTS 帧来预约信道。尽管 C 收不到该 RTS 帧,但是 C 可以收到 B 发送给 A 的 CTS 帧:

在这里插入图片描述

这样 C 就知道了信道将被占用多长时间。在这段时间内,C 都不会征用信道,也就是说 A 给 B 发送数据不会受到 C 干扰。


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

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

相关文章

腾讯云轻量应用服务器端口开启教程

腾讯云轻量应用服务器端口怎么打开?在轻量应用服务器控制台的防火墙中开启端口,本文腾讯云百科txybk.com以80端口为例,来详细说下轻量应用服务器端口打开教程,另外可以在腾讯云百科 txy.wiki 查看当前轻量服务器最新的优惠券和配置…

大隐市苏州

大隐隐于市的典型:苏州。 中国四大园林,二个在苏州,实际上看多逛多了苏州园林,其它地方的园林真的就是太不精致了~~~~ 哈哈,莫打莫打。 将山水装入庭院,情怀显露山水间。 看似宅男一个,实则依旧…

康耐视visionpro-CoglntersectLineLineTool操作说明工具详细说明

◆CogIntersectLineLineTool功能说明: 创建两条线的交点 备注:在“Geometry-Intersection”选项中的所有工具都是创建两个图形的交点工具,其中包括圆与圆的交点、线与圆的交点、线与线的交点、线与圆的交点等,工具使用的方法相似。…

视频国标学习

总体介绍 GB/T28181协议,全名叫《安全防范视频监控联网系统信息传输、交换、控制技术要求》,是由中国国家标准委员会发布的一种国家级的标准。它主要对视频监控系统的各个方面做了明确的规定,使得不同厂商生产的视频监控设备能够相互连通&am…

一种基于OpenCV的图片倾斜矫正方法

需求描述: 对倾斜的图片进行矫正,返回倾斜角度和矫正后的图片。 解决方法: 1、各种角度点被投影到一个累加器阵列中,其中倾斜角度可以定义为在最大化对齐的搜索间隔内的投影角度。 2、以不同的角度旋转图像,并为每…

参会记录|全国多媒体取证暨第三届多媒体智能安全学术研讨会(MAS‘2024)

前言:2024年4月13日上午,我与实验室的诸位伙伴共聚江西南昌的玉泉岛大酒店,参加了为期一天半的全国多媒体取证暨第三届多媒体智能安全学术研讨会(MAS’2024)。本届学术研讨会由江西省计算机学会、江西省数字经济学会主…

PHP:IntelliJ IDEA 配置 PHP 开发环境及导入PHP项目

在创建PHP项目之前我们需要安装PHP插件,安装步骤如下:Windows:IntelliJ IDEA Ultimate 安装 PHP 插件-CSDN博客 1、导入已有PHP项目,导入之后选择,File > Setting 选择对应 CLL Interpreter,如果没有操…

GitHub登录收不到邮箱验证码

由于长时间没有登录GitHub,浏览器可能清除了相应的cookie信息,所以需要对应绑定邮箱进行验证,但因为邮箱长时间没有收到验证码,所以给到以下一种可能解决的方法: 需要输入验证码进行验证 我们可以打开QQ邮箱&#xff0…

java的深入探究JVM之类加载与双亲委派机制

前言 前面学习了虚拟机的内存结构、对象的分配和创建,但对象所对应的类是怎么加载到虚拟机中来的呢?加载过程中需要做些什么?什么是双亲委派机制以及为什么要打破双亲委派机制? 类的生命周期 类的生命周期包含了如上的7个阶段&a…

光场相机建模与畸变校正改进方法

摘要:光场相机作为一种新型的成像系统,可以直接从一次曝光的图像中得到三维信息。为了能够更充分有效地利用光场数据包含的角度和位置信息,完成更加精准的场景深度计算,从而提升光场相机的三维重建的精度,需要实现精确…

比特币突然暴跌

作者:秦晋 周末愉快。 今天给大家分享两则比特币新闻,也是两个数据。一则是因为中东地缘政治升温,传统资本市场的风险情绪蔓延至加密市场,引发加密市场暴跌。比特币跌至66000美元下方。杠杆清算金额高达8.5亿美元。 二则是&#x…

Spring(24) Json序列化的三种方式(Jackson、FastJSON、Gson)史上最全!

目录 一、Jackson 方案(SpringBoot默认支持)1.1 Jackson 库的特点1.2 Jackson 的核心模块1.3 Maven依赖1.4 代码示例1.5 LocalDateTime 格式化1.6 统一配置1.7 常用注解1.8 自定义序列化和反序列化1.9 Jackson 工具类 二、FastJSON 方案2.1 FastJSON 的特…

Redis消息队列-基于PubSub的消息队列

7.3 Redis消息队列-基于PubSub的消息队列 PubSub(发布订阅)是Redis2.0版本引入的消息传递模型。顾名思义,消费者可以订阅一个或多个channel,生产者向对应channel发送消息后,所有订阅者都能收到相关消息。 SUBSCRIBE …

【练习】二分查找

1、704 &#xff08;1&#xff09;题目描述 &#xff08;2&#xff09;代码实现 package com.hh.practice.leetcode.array.demo_02;public class BinarySearch_704 {public int search(int[] nums, int target) {int i 0,j nums.length -1;while (i < j){int mid (ij) &…

【QT+QGIS跨平台编译】181:【QGIS+Qt跨平台编译】—【错误处理:找不到_DEBUGA】

点击查看专栏目录 文章目录 一、找不到_DEBUGA二、原因分析三、错误处理 一、找不到_DEBUGA 报错信息&#xff1a; 二、原因分析 采用了非UNICODE&#xff1a; DEFINES - UNICODE没法识别 _DEBUGA 但可以识别 _DEBUG 三、错误处理 修改 _DEBUGA 为 _DEBUG

C语言专项训练

道阻且长&#xff0c;接下来就要开始数据结构的学习&#xff0c;而学不可以不练&#xff0c;在接下来的学习中&#xff0c;数据结构学习的同时&#xff0c;c语言训练也要开始更新了&#xff5e; NO.1 函数 1.void函数声明 这道题一看就秒了(开玩笑)我们在知道答案的同时&#…

Linux多进程开发2 - 进程间通信

1、进程间通信的概念 进程是一个独立的资源分配单元&#xff0c;不同进程之间的资源是独立的&#xff0c;没有关联&#xff0c;不能在一个进程中直接访问另一个进程的资源。但是&#xff0c;进程不是孤立的&#xff0c;不同的进程需要进行信息的交换和状态的传递等&…

【YOLOV5 入门】——Pyside6/PyQt5可视化UI界面后端逻辑

声明&#xff1a;笔记是做项目时根据B站博主视频学习时自己编写&#xff0c;请勿随意转载&#xff01; 一、环境安装 VScode/Pycharm终端进入虚拟环境后&#xff0c;输入下面代码安装pyside6&#xff0c;若用的Pycharm作为集成开发环境&#xff0c;也下载个pyqt5&#xff1a; …

得物 Zookeeper SLA 也可以 99.99% | 得物技术

一、背景 ZooKeeper&#xff08;ZK&#xff09;是一个诞生于2007年的分布式应用程序协调服务。尽管出于一些特殊的历史原因&#xff0c;许多业务场景仍然不得不依赖它。比如&#xff0c;Kafka、任务调度等。特别是在 Flink 混合部署 ETCD 解耦 时&#xff0c;业务方曾要求绝对…

C语言之探秘:访问结构体空指针与结构体空指针的地址的区别(九十三)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…