首页 > 编程知识 正文

计算机网络五层(数据链路层实现了)

时间:2023-05-04 05:25:02 阅读:78480 作者:1677

数据链路层使用的通道主要有以下两种:

点对点通道:此通道使用一对一的点对点通信方式。 广播频道:该频道使用一对多的广播通信方式。 由于广播通道有很多主机连接,因此必须使用专用的共享通道协议来协调这些主机的数据传输。 链路(link )是被动点对点物理线路段,中间没有其他交换节点。

除物理线路外,数据链路(data link )还需要用于控制这些数据传输的通信协议。 当实现这些协议的硬件和软件被添加到链接时,构成数据链接。

目前最常用的方法是使用适配器(即网卡)实现这些协议的硬件和软件。

计算机通过适配器与局域网通信。

三个基本问题

封装成帧

封装到帧中(成帧)是指在一个数据的前后分别添加标头和尾部,构成一个帧。 确定框架边界。

如果

透明传输

数据中某个字节的二进制代码正好与SOH或EOT相同,则数据链路层会错误地“找到帧边界”。

解决方法:字节填充(字节填充)或位填充。

字节装:

比特填充:

差错检测

在传输过程中可能会发生位错误。 1可能为0,0可能为1。

暂时地,传输错误的比特数目与所传输的比特总数的比率被称为比特错误率ber (比特错误率)。

在数据链路层传输帧中,对CRC进行循环冗馀检查的错误检测技术被广泛使用。

冗馀代码的计算

假设要传输的数据集M=101001 (当前k=6)。 我们在m后面添加用于检错的n位冗馀码一起发送。

用二进制的2级运算进行2^n乘以m的运算。 这相当于在m之后添加n个0。

将得到的(kn )位的数量除以预选的长度(n 1)位的除数p,商为q,馀数为r,馀数r比除数p少1位,即r为n位。

将馀数r作为冗馀代码连接在数据m的后面进行发送。

附加在数据后面的冗馀代码称为帧检查序列FCS(framechecksequence )。

FCS可以通过称为CRC的方法获得,而CRC不是获得FCS的唯一方法。

接收端对每帧进行CRC检查

当获得馀数R=0时,则判断为该帧没有错误,接受(接受)。

剩余r!=0时,判断为该帧有错误,并丢弃。

如果只是循环冗馀检查CRC错误检测技术,则只能无错误地接受(accept )。

要实现“可靠的传输”,即发送什么和接收什么,需要添加确认和重发机制。

在数据链路层使用CRC检查可以实现非常特殊的错误传输,但这还不是可靠的传输。 这里介绍的数据链路层协议都不是可靠传输的协议。

对于

点对点协议PPP

点对点链路,当前最广泛使用的数据链路层协议是点对点协议点对点协议(PPP )。

如果用户通过拨号电话线访问互联网,则用户计算机与ISP通信时使用的数据链路层协议是PPP协议。

PPP帧格式

PPP是面向字节的,所有PPP帧的长度都是整数字节。

标志字段F=0x7E; 地址字段a仅限0xFF; 控制字段c通常设置为0x03。

PP有两个字节的协议字段。 那个值

对于0x0021,信息字段为IP数据报。0x8021时,信息字段为网络控制数据。 对于0xC021,信息字段是PPP链路

控制数据。若为 0xC023,则信息字段是鉴别数据。

透明传输问题

异步传输 - 字符填充

将信息字段中出现的每一个 0x7E 字节转变成为 2 字节序列 (0x7D, 0x5E)。

若信息字段中出现一个 0x7D 的字节, 则将其转变成为 2 字节序列 (0x7D, 0x5D)。

若信息字段中出现 ASCII 码的控制字符(即数值小于 0x20 的字符),则在该字符前面要加入一个 0x7D 字节,同时将该字符的编码加以改变。

同步传输 - 零比特填充

在发送端,只要发现有 5 个连续 1,则立即填入一个 0。

接收端对帧中的比特流进行扫描。每当发现 5 个连续1时,就把这 5 个连续 1 后的一个 0 删除。

使用广播信道的数据链路层

以太网

DIX Ethernet V2 是世界上第一个局域网产品(以太网)的规约。

IEEE 802.3 是第一个 IEEE 的以太网标准。

DIX Ethernet V2 标准与 IEEE 的 802.3 标准只有很小的差别,因此

可以将 802.3 局域网简称为“以太网”(Ethernet)。

数据链路层的两个子层

IEEE 802 委员会就将局域网的数据链路层拆成两个子层:

逻辑链路控制 LLC (Logical Link Control)子层;

媒体接入控制 MAC (Medium Access Control)子层。

由于 TCP/IP 体系经常使用的局域网是 DIX Ethernet V2 而不是 802.3 标准中的几种局域网,因此现在 802 委员会制定的逻辑链路控制子层 LLC(即 802.2 标准)的作用已经不大了。故我们一般不考虑 LLC 子层,仅考虑 MAC层。

CSMA/CD协议

为了通信的简便,以太网采取了两种重要的措施:

(1) 采用较为灵活的无连接的工作方式

不必先建立连接就可以直接发送数据。

对发送的数据帧不进行编号,也不要求对方发回确认。

这样做的理由是局域网信道的质量很好,因信道质量产生差错的概率是很小的。

以太网提供的服务是不可靠的交付,即尽最大努力的交付。

当目的站收到有差错的数据帧时就丢弃此帧,其他什么也不做。差错的纠正由高层来决定。

(2) 以太网发送的数据都使用曼彻斯特 (Manchester)编码

CSMA/CD协议的含义

CSMA/CD即载波监听多点接入 / 碰撞检测 (Carrier Sense Multiple Access with Collision Detection)。

“载波监听”:用电子技术检测总线上有没有其他计算机发送的数据信号。

“多点接入”:表示许多计算机以多点接入的方式连接在一根总线上。

“碰撞检测”:就是计算机边发送数据边检测信道上的信号电压大小。

当一个站检测到的信号电压摆动值超过一定的门限值时,就认为总线上至少有两个站同时在发送数据,表明产生了碰撞。

所谓“碰撞”就是发生了冲突。因此“碰撞检测”也称为“冲突检测”。

每一个正在发送数据的站,一旦发现总线上出现了碰撞,就要立即停止发送,免得继续浪费网络资源,然后等待一段随机时间后再次发送。

为什么要碰撞检测?

由于电磁波在总线上的传播速率是有限的。

笑点低的诺言在 A 发送的信息到达 B 之前发送自己的帧 (因为这时 B 的载波监听检测不到 A 所发送的信息),则必然要在某个时间和 A 发送的帧发生碰撞。

CSMA/CD 重要特性

使用 CSMA/CD 协议的以太网不能进行全双工通信而只能进行双向交替通信(半双工通信)。

每个站在发送数据之后的一小段时间内,存在着遭遇碰撞的可能性。

这种发送的不确定性使整个以太网的平均通信量远小于以太网的最高数据率。

争用期

最先发送数据帧的站,在发送数据帧后至多经过时间 2τ (两倍的端到端往返时延)就可知道发送的数据帧是否遭受了碰撞。

以太网的端到端往返时延 2τ 称为争用期,或碰撞窗口。

10 Mbit/s 以太网取 51.2 μs 为争用期的长度。

对于 10 Mbit/s 以太网,在争用期内可发送 512 bit,即 64 字节。

由此,以太网规定了最短有效帧长为 64 字节,凡长度小于 64 字节的帧都是由于冲突而异常中止的无效帧。

二进制指数类型退避算法

k = min[重传次数, 10]

r = random[0,1,...,(2^k-1)]

时延 = r*2τ(基本退避时间)

强化碰撞

当发送数据的站一旦发现发生了碰撞时,便立即停止发送数据;

再继续发送若干比特的人为干扰信号(jamming signal),以便让所有用户都知道现在已经发生了碰撞。

CSMA/CD协议的要点

(1)检测信道:在发送前,必须先检测信道。

若检测到信道忙,则应不停地检测,一直等待信道转为空闲。若检测到信道空闲,并在 96 比特时间内信道保持空闲(保证了帧间最小间隔),就发送这个帧。

(2)检测碰撞:

在发送过程中仍不停地检测信道,即网络适配器要边发送边监听。

①发送成功:在争用期内一直未检测到碰撞。这个帧肯定能够发送成功。

②发送失败:在争用期内检测到碰撞。这时立即停止发送数据,并按规定发送人为干扰信号。适配器接着就执行指数退避算法,等待 r 倍 512 比特时间后,返回到步骤 (1),继续检测信道。但若重传达 16 次仍不能成功,则停止重传而向上报错。

帧间最小间隔

帧间最小间隔为 9.6 μs,相当于 96 bit 的发送时间。

一个站在检测到总线开始空闲后,还要等待 9.6 μs 才能再次发送数据。

这样做是为了使刚刚收到数据帧的站的接收缓存来得及清理,做好接收下一帧的准备。

以太网的物理层基础 -- 使用集线器的星形拓扑

采用双绞线的以太网采用星形拓扑,在星形的中心则增加了一种可靠性非常高的设备,叫做集线器 (hub)。集线器很像一个多接口的转发器,工作在物理层。

使用集线器的以太网在逻辑上仍是一个总线网,各工作站使用的还是 CSMA/CD 协议,并共享逻辑上的总线。

以太网的信道利用率 -- 以α参数表示

在以太网中定义了参数 α,它是以太网单程端到端时延τ与帧的发送时间 T0 之比:

α = τ/T0

为提高利用率,以太网的参数a的值应当尽可能小些。

当数据率一定时,以太网的连线的长度受到限制,否则  的数值会太大。以太网的帧长不能太短,否则 T0 的值会太小,使 α 值太大。

以太网的MAC层

MAC地址

生产适配器时,6 字节的 MAC 地址已被固化在适配器的 ROM,因此,MAC 地址也叫做硬件地址 (hardware address)或物理地址。

“MAC地址”实际上就是适配器地址或适配器标识符 EUI-48。

48位(6字节)的MAC地址称为 MAC-48,它的通用名称是 EUI-48。

前三个字节由IEEE 的注册管理机构 RA 负责向厂家分配,称为组织唯一标识符。

后三个字节由厂家自行指派,称为扩展唯一标识符,必须保证生产出的适配器没有重复地址。

适配器从网络上每收到一个 MAC 帧就首先用硬件检查 MAC 帧中的 MAC 地址。

如果是发往本站的帧则收下,然后再进行其他的处理。

否则就将此帧丢弃,不再进行其他的处理。

MAC帧格式:

常用的以太网 MAC 帧格式有两种标准,最常用的 MAC 帧是以太网 V2(DIX Ethernet V2) 的格式。

类型字段用来标志上一层使用的是什么协议,以便把收到的 MAC 帧的数据上交给上一层的这个协议。

数据字段的正式名称是 MAC 客户数据字段。

数据字段的最小长度(46字节)= 最短有效帧长(64字节) - 首部和尾部(18字节)。

当数据字段的长度小于 46 字节时,应在数据字段的后面加入整数字节的填充字段。

在帧的前面插入(硬件生成)的 8 字节中,第一个字段共 7 个字节,是前同步码,用来迅速实现 MAC 帧的比特同步。第二个字段 1 个字节是帧开始定界符,表示后面的信息就是 MAC 帧。

扩展的以太网

在物理层扩展以太网 --- 使用集线器扩展

集线器工作在物理层,每个端口相当于一个中继器,用于扩展终端数量。

集线器共享带宽,带宽为多个端口所瓜分。碰撞域增大了,但总的吞吐量并未提高。

如果不同的碰撞域使用不同的数据率,那么就不能用集线器将它们互连起来。

在数据链路层扩展以太网 --- 使用交换机扩展

交换机工作在数据链路层,每个端口相当于一个集线器,原理是根据数据帧头的MAC地址转发帧到合适的端口,每个端口是一个独立的冲突域。

能同时连通多对接口,使多对主机能同时通信。

交换机每个端口独享带宽,无碰撞地传输数据。

现在,采用以太网交换机的星形结构成为以太网的首选拓扑。

以太网交换机不使用共享总线,没有碰撞问题,因此不使用 CSMA/CD 协议,而是以全双工方式工作。但仍然采用以太网的帧结构。

交换机通过自学习算法处理收到的帧和建立交换表

A 先向 B 发送一帧,从接口1 进入到交换机。交换机收到帧后,先查找交换表,没有查到应从哪个接口转发这个帧。交换机把这个帧的源地址 A 和接口 1 写入交换表中,并向除接口1以外的所有的接口广播这个帧。C 和 D 将丢弃这个帧,因为目的地址不对。只 B 才收下这个目的地址正确的帧。这也称为过滤。B 通过接口3 向 A 发送一帧。交换机查找交换表,发现交换表中的 MAC 地址有 A。表明要发送给A的帧(即目的地址为 A 的帧)应从接口1转发。于是就把这个帧传送到接口 1 转发给 A。显然,现在已经没有必要再广播收到的帧。交换表这时新增加的项目 (B, 3),表明今后如有发送给 B 的帧,就应当从接口 3 转发出去。

高速以太网

100BASE-T以太网

可在全双工方式下工作而无冲突发生。在全双工方式下工作时,不使用 CSMA/CD 协议。

MAC 帧格式仍然是 802.3 标准规定的。

保持最短帧长不变,但将一个网段的最大电缆长度减小到 100 m。

帧间时间间隔从原来的 9.6 μs 改为现在的 0.96 μs。

吉比特以太网

在半双工方式下使用 CSMA/CD 协议,全双工方式不使用 CSMA/CD 协议。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。