CSMA/CD解释与理解
1. CSMA/CD含义
CSMA/CD即载波监听多点接入/碰撞检测,此协议是使用在总线型网络中的,不同计算机是通过多点接入的方式连接在一起。协议的重点在于监听和碰撞检测。
2. 为什么要监听和碰撞检测
当初学习的时候,对于为什么要监听空闲和检测碰撞一直很疑惑,其实原因很简单,对于总线型网络来说,如果有多个主机同时发送信号,那么是很难从中分辨出信息的。举个栗子就是一堆不同频率相位的正弦混合在一起,让你从波形图中画出某条正弦曲线,是不是感觉非常的困难?为了避免在网络中遇到这个问题,所以采用载波监听和碰撞检测的方法。
3.载波监听用处
载波监听其实就是检测信道是不是为空,如果是,那么就可以发送自己的信息了。如果信道正忙,那么只能等到信道空闲,才能发送自己的信息。那么,是不是只要空闲发送自己的信息就永远不会出错呢?当然不是,我们联系生活中的一个栗子就能知道,当开会讨论的时候,如果一片安静,那么之后就可能会有两个或者多个人同时开始说话发言。信道上也是如此,甚至更加明显。因为载波监听只能是在自己的位置监听,而从别的主机发送过来的信号需要时间。这就不可避免的会出现主机B明明发送了信息,但是主机A没有发现,也发送一个信息出来,这样便会发生碰撞,导致数据信号失真。
4.碰撞检测用处
碰撞检测就是为了解决上面说的同时发送,或者说在很短时间(B发送信号尚未到达A)内同时发送引发的碰撞问题。碰撞检测即适配器在发送数据的过程中也要检测信道信号,若发现信号电压变化幅度增大超过某个阈值,则认为发生碰撞。
5.截断二进制指数退避
发送了碰撞怎么办?当然是停止发送,找个合适的时间再发送。那么怎么寻找一个合适的时间呢?那就要用到截断二进制指数退避,这个名字听起来很高端大气,其实很简单。首先我们明确一个概念,叫做争用期。什么叫争用期,就是在这个发送信息后的这段时间内可能发生碰撞,但是过了这个争用期,那么就一定不会发生碰撞。我们把争用期定义为两倍的端到端传播时延,如下图,δ足够小的时候,A要经过2τ的时间才能发现碰撞。
退避算法:
1.从[0,1,2, ...,(2^k-1)]中随机选一个数,记为r。重传应在r倍争用期之后进行。k的取值为Min[重传次数,10],即k小于10时为重传次数,最大不超过10 。
2.若重传超过16次还是不成功,则说明信道中数据过多,放弃重传,向高层报告。
6.最短帧长
那么,经历了上面的一系列操作,我们是不是可以保证信道中不会存在冲突了呢?答案是,不能。我们要注意到我们的碰撞检测和监听都是在本机的位置上进行的,不能够跑到别的信道位置上进行。那么这样就存在了一个问题,那就是要发送的信息过短,导致碰撞检测在发送该信息的时候没有检测到碰撞,但是在发送出去之后,这个信息与其他的信息碰撞。就好像你寄东西,寄出去的时候还是好好的,等送到别人手里变得一塌糊涂,这就是在寄的过程中发生了冲突。解决办法很简单,就是增加信息长度。以太网规定最短帧长为64字节,对于10Mbit/s以太网,发送64字节(512bit)数据需要51.2us,也就是上面的争用期。这样如果发生碰撞,那么一定能在自己这边检测出来,因为自己的信号和别人发送的信号混在一起,导致信号电压变化超过阈值。如果发送完了,那么自己是不知道自己发送的东西在路上有没有出现意外,这个就只有接收方才能知道,会把这个丢弃,但是自己不会再次发送,这就导致数据的丢失。并且由于发现冲突就会停止发送,所以可以认为,凡是长度小于64字节的帧都是由于冲突而停止发送无效帧。
7.强化碰撞
在发送数据的时候发生冲突,除了停止发送用户数据,还要继续发送32bit或者48bit的干扰信号,目的就是为了让所有用户都知道现在发生了冲突。
CSMA/CD解释与理解的更多相关文章
- CSMA/CD ,现在的交换式以太网还用吗?谈全双工,半双工与CSMA/CD的关系
我们知道:以太网访问控制用的是CSMA/CD,即载波侦听多点接入/ 冲突检测,是以广播的方式将数据发送到所有端口: 我们还知道:交换机能主动学习端口所接设备的MAC地址,在获知该端口的MAC 地址后, ...
- 计算机网络之介质访问控制(静态划分信道、FDM、TDM、STDM、WDM、CDM)、(动态划分信道、ALOHA、CSMA、CSMA/CD、CSMA/CA)、令牌传递协议
文章转自:https://blog.csdn.net/weixin_43914604/article/details/104935912 学习课程:<2019王道考研计算机网络> 学习目的 ...
- 2016.6.20 计算机网络复习要点第三章之CSMA/CD协议
1.最早的以太网是将许多计算机都连接到一根总线上: (1)总线的特点是:当一台计算机发送数据时,总线上的所有计算机都检测到这个数据,这种就是广播通信方式: (2)为了实现在总线上的一对一通信,可以使每 ...
- CSMA/CD协议——学习笔记
CSMA/CD协议要点: 1)适配器从网络层获得一个分组,加上以太网的首部和尾部,组成以太网帧,放入适配器的缓存中,准备发送. 2)若适配器检测到信道空闲(即在96比特时间内没有检测到信道上有信号), ...
- CSMA/CD协议
为了通信的简便,以太网采取了两种重要的措施: 第一:采用较为灵活的无连接的工作方式,即不必先建立连接就可以直接发送数据: 第二:以太网对发送的数据帧不进行编号,也不要求对方发回确认. 因此,以太网提供 ...
- 介质共享型局域网中的介质访问控制(MAC)协议需要具体解决的3个问题,CSMA/CD介质访问控制的基本思想
1,在某一时刻,那个节点可以发送数据 2,发送时是否会出现冲突 3,出现冲突时如何处理 CSMA/CD介质访问控制的基本思想:先监听,再发送.边发送,边监听,如发生冲突,则等待一段时间后再次发送
- 重学 以太网的mac协议的CSMA/CD
之前上课一直模糊的CSMA/CD进行系统性整理. CSMA/CD (Carrier Sense Multiple Acess/Collision Detect)应用在OSI的 数据链路层 在以太网中, ...
- 计算机网络【2】—— CSMA/CD协议
参考文献: https://blog.csdn.net/loveCC_orange/article/details/79177129 一.认识以太网 最早的以太网是将许多计算机都连接到一根总线上. 使 ...
- CSMA/CD 3
一.二进制指数类型退避算法 (truncated binary exponential type) 发生碰撞的站在停止发送数据后,要推迟(退避)一个随机时间才能再发送数据. 目的:重传时再次发生碰撞的 ...
随机推荐
- SQL表操作习题3 11~13题
- 解魔方的机器人攻略14 – 安装Lejos(下)
由 动力老男孩 发表于 2009/12/27 17:16:11 第四步:安装Lejos 登陆 Lejos 主页点击 NXT 图片进入 Lejos 下载页面,点击 NXJ 的下载链接: 下载完成后将下载 ...
- Delphi CRC16校验算法实现(转)
循环冗余码校验英文名称为Cyclical Redundancy Check,简称CRC.它是利用除法及余数的原理来作错误侦测(Error Detecting)的.实际应用时,发送装置计算出CRC值并随 ...
- delphi crc校验函数
function CalCRC16(AData: array of Byte; AStart, AEnd: Integer): string;const GENP=$8408; //多项式公式X1 ...
- 关于select 控件
通过http://www.w3school.com.cn/tiy/t.asp?f=html_select 的测试,测得,select 控件值最多106个. Q:easyui的datagrid中能做到 ...
- SQL SERVER 2012 尝试读取或写入受保护的内存。这通常指示其他内存已损坏。 (System.Data)
标题: 连接到服务器------------------------------ 无法连接到 192.168.1.253. ------------------------------其他信息: 尝试 ...
- mysql update 的时候使用left join和where语句
在使用update语句的时候我们有时候需要利用left join 关联表,以下是正确操作: 效果,让指定的order表id为1,2,3数据的finish_at字段更新为freports表的create ...
- EffectiveJava(21)策略模式多种方式实现字符串比较
**调用对象上的方法通常是执行该对象上的某项操作**. 如果一个对象的方法执行其他对象的操作,一个类仅仅导出这个方法(它的实例相当于一个指向该方法的指针),这样的实例被称为函数对象 例如: /** * ...
- react-native 极光推送(jpush-react-native)
极光推送官方支持的 React Native 插件 安装 npm install jpush-react-native --savenpm install jcore-react-native --s ...
- 为什么要上大四???why
毕业证 即将要上大四了.近期一直在思考,毕业证对于我有什么作用呢?我从来不忌讳表露自己的观点.哪怕这个观点是错误的. 如今这个观点,想必又要激起无数人对我的责骂吧? 但是毕 ...