计算机网络ch4-点对点信道的数据链路层 2ed

上传人:子 文档编号:52135933 上传时间:2018-08-18 格式:PPT 页数:39 大小:411KB
返回 下载 相关 举报
计算机网络ch4-点对点信道的数据链路层 2ed_第1页
第1页 / 共39页
计算机网络ch4-点对点信道的数据链路层 2ed_第2页
第2页 / 共39页
计算机网络ch4-点对点信道的数据链路层 2ed_第3页
第3页 / 共39页
计算机网络ch4-点对点信道的数据链路层 2ed_第4页
第4页 / 共39页
计算机网络ch4-点对点信道的数据链路层 2ed_第5页
第5页 / 共39页
点击查看更多>>
资源描述

《计算机网络ch4-点对点信道的数据链路层 2ed》由会员分享,可在线阅读,更多相关《计算机网络ch4-点对点信道的数据链路层 2ed(39页珍藏版)》请在金锄头文库上搜索。

1、计算机网络教程(第 2 版)第 4 章 点对点信道的数据链路层第 4 章 点对点信道的数据链路层4.1 数据链路层的基本概念4.1.1 数据链路层的简单模型4.1.2 链路和数据链路 4.2 三个基本问题4.2.1 帧定界4.2.2 透明传输4.2.3 差错检测 4.3 点对点协议 PPP4.3.1 PPP 协议的特点4.3.2 PPP 协议的帧格式4.3.3 PPP 协议的工作状态 4.4 HDLC 协议数据链路层数据链路层使用的信道主要有以下两种类 型:n点对点信道。这种信道使用一对一的点 对点通信方式。n广播信道。这种信道使用一对多的广播 通信方式,因此过程比较复杂。广播信 道上连接的主

2、机很多,因此必须使用专 用的共享信道协议来协调这些主机的数 据发 4.1 数据链路层的基本概念 4.1.1 数据链路层的简单模型局域网广域网主机 H1主机 H2路由器 R1路由器 R2路由器 R3电话网局域网主机 H1 向 H2 发送数据链路层应用层运输层网络层物理层链路层应用层运输层网络层物理层链路层网络层物理层链路层网络层物理层链路层网络层物理层R1R2R3H1H2从层次上来看数据的流动数据链路层的简单模型( 续)局域网广域网主机 H1主机 H2路由器 R1路由器 R2路由器 R3电话网局域网主机 H1 向 H2 发送数据链路层应用层运输层网络层物理层链路层应用层运输层网络层物理层链路层网

3、络层物理层链路层网络层物理层链路层网络层物理层R1R2R3H1H2仅从数据链路层观察帧的流动IP 数据报1010 0110帧取出数据 链路层网络层链路结点 A结点 B物理层数据 链路层结点 A结点 B帧(a)(b)发送 帧接收链路IP 数据报1010 0110帧装入数据链路层传送的是帧数据链路层像个数字管道 n常常在两个对等的数据链路层之间画出 一个数字管道,而在这条数字管道上传 输的数据单位是帧。n早期的数据通信协议曾叫作通信规程 (procedure)。因此在数据链路层,规程 和协议是同义语。 结点结点帧帧4.1.2 链路和数据链路 n链路(link)是一条无源的点到点的物理线 路段,中间

4、没有任何其他的交换结点。n一条链路只是一条通路的一个组成部分。n数据链路(data link) 除了物理线路外,还必须 有通信协议来控制这些数据的传输。若把实现 这些协议的硬件和软件加到链路上,就构成了 数据链路。n现在最常用的方法是使用适配器(即网卡)来实现 这些协议的硬件和软件。n一般的适配器都包括了数据链路层和物理层这两层 的功能。 4.2 三个基本问题 (1) 帧定界 (2) 透明传输 (3) 差错控制 4.2.1 帧定界n帧定界(framing)就是确定帧的界限。 帧结束帧首部IP 数据报帧的数据部分帧尾部 MTU数据链路层的帧长从这里开始发送帧开始用控制字符进行帧定界的方法举例 S

5、OH装在帧中的数据部分帧帧开始符帧结束符发送在前EOT4.2.2 透明传输SOHEOT出现了“EOT”被接收端当作无效帧而丢弃被接收端 误认为是一个帧数据部分EOT完整的帧发送在前解决透明传输问题n发送端的数据链路层在数据中出现控制字符“SOH” 或“EOT”的前面插入一个转义字符“ESC”(其十六进 制编码是 1B)。n字节填充(byte stuffing)或字符填充(character stuffing)接收端的数据链路层在将数据送往网 络层之前删除插入的转义字符。n如果转义字符也出现数据当中,那么应在转义字 符前面插入一个转义字符。当接收端收到连续的 两个转义字符时,就删除其中前面的一个

6、。 SOHSOHESCSOHEOTESCESCzESCyESCzESCx原始数据EOTEOT经过字节填充后发送的数据字节填充字节填充字节填充字节填充发送 在前帧开始符帧结束符用字节填充法解决透明传输的问题 3. 差错检测n比特在传输过程中可能会产生差错:1 可能会 变成 0 而 0 也可能变成 1。n在一段时间内,传输错误的比特占所传输比特 总数的比率称为误码率 BER (Bit Error Rate)。n误码率与信噪比有很大的关系。n为了保证数据传输的可靠性,在计算机网络传 输数据时,必须采用各种差错检测措施。 循环冗余检验的原理 n在数据链路层传送的帧中,广泛使用了循 环冗余检验 CRC

7、的检错技术。n在发送端,先把数据划分为组。假定每组 k 位。 n假设待传送的一组数据 M = 101001(现在 k = 6)。我们在 M 的后面再添加供差错检 测用的 n 位冗余码一起发送。 冗余码的计算 n用二进制的模 2 运算进行 2n 乘 M 的运算 ,这相当于在 M 后面添加 n 个 0。n得到的 (k + n) 位的数除以事先选定好的 长度为 (n + 1) 位的除数 P,得出商是 Q 而余数是 R,余数 R 比除数 P 少1 位( n 位)。 冗余码的计算举例 n现在 k = 6, M = 101001。n设 n = 3, 除数 P = 1101,n被除数是 2nM = 1010

8、01000。 n模 2 运算的结果是:商 Q = 110101,余数 R = 001。n把余数 R 作为冗余码添加在数据 M 的后面发 送出去。发送的数据是:2nM + R 即:101001001,共 (k + n) 位。 110101 Q (商)P (除数) 1101 101001000 2nM (被除数)11011110 110101110000111011010110000011001101001 R (余数),作为 FCS 循环冗余检验的原理说明 帧检验序列 FCS n在数据后面添加上的冗余码称为帧检验 序列 FCS (Frame Check Sequence)。n循环冗余检验 CRC

9、 和帧检验序列 FCS 并不等同。nCRC 是一种常用的检错方法,而 FCS 是添 加在数据后面的冗余码。nFCS 可以用 CRC 这种方法得出,但 CRC 并非用来获得 FCS 的唯一方法。 接收端对收到的每一帧进行 CRC 检验 n(1) 若得出的余数 R = 0,则判定这个帧没有差 错,就接受(accept)。n(2) 若余数 R 0,则判定这个帧有差错,就丢 弃。n但这种检测方法并不能确定究竟是哪一个或哪 几个比特出现了差错。n只要经过严格的挑选,并使用位数足够多的除 数 P,那么出现检测不到的差错的概率就很小 很小。 应当注意 n仅用循环冗余检验 CRC 差错检测技术只能做 到无差错

10、接受(accept)。n“无差错接受”是指:“凡是接受的帧(即不包括 丢弃的帧),我们都能以非常接近于 1 的概率 认为这些帧在传输过程中没有产生差错”。n也就是说:“凡是接收端数据链路层接受的帧都 没有传输差错”(有差错的帧就丢弃而不接受) 。n要做到“可靠传输”(即发送什么就收到什么) 就必须再加上确认和重传机制。 4.3 点对点协议 PPP 4.3.1 点对点协议的特点 n现在全世界使用得最多的数据链路层协 议是点对点协议 PPP (Point-to-Point Protocol)。n用户使用拨号电话线接入因特网时,一 般都是使用 PPP 协议。 用户到 ISP 的链路使用 PPP 协议

11、 用户至因特网已向因特网管理机构 申请到一批 IP 地址ISP接入网PPP 协议1. PPP 协议应满足的需求 n简单n封装成帧 n透明性 n多种网络层协议 n多种类型链路 n差错检测 n检测活跃度(即检测连接状态) n最大传送单元 n网络层地址协商 n数据压缩协商 2. PPP 协议不需要的功能n纠错 n流量控制 n序号 n多点线路 n半双工或单工链路 3. PPP 协议的组成 n1992 年制订了 PPP 协议。经过 1993 年 和 1994 年的修订,现在的 PPP 协议已 成为因特网的正式标准RFC 1661。 nPPP 协议有三个组成部分 n一个将 IP 数据报封装到串行链路的方法

12、。n链路控制协议 LCP (Link Control Protocol) 。n网络控制协议 NCP (Network Control Protocol)。 4.3.2 PPP 协议的帧格式n标志字段 F = 0x7E (符号“0x”表示后面 的字符是用十六进制表示。十六进制的 7E 的二进制表示是 01111110)。n地址字段 A 只置为 0xFF。地址字段实际 上并不起作用。n控制字段 C 通常置为 0x03。nPPP 是面向字节的,所有的 PPP 帧的 长度都是整数字节。 PPP 协议的帧格式nPPP 有一个 2 个字节的协议字段。n当协议字段为 0x0021 时,PPP 帧的信息字段就

13、是 IP 数据报。n若为 0xC021, 则信息字段是 PPP 链路控制数据。n若为 0x8021,则表示这是网络控制数据。 IP 数据报1211字节12不超过 1500 字节 PPP 帧先发送7EFF03FACFCSF7E协议信 息 部 分首部尾部透明传输问题 n当 PPP 用在同步传输链路时,协议规定 采用硬件来完成比特填充(和 HDLC 的 做法一样)。 n当 PPP 用在异步传输时,就使用一种特 殊的字符填充法。 字符填充 n将信息字段中出现的每一个 0x7E 字节转 变成为 2 字节序列(0x7D, 0x5E)。 n若信息字段中出现一个 0x7D 的字节, 则将 其转变成为 2 字节

14、序列(0x7D, 0x5D)。n若信息字段中出现 ASCII 码的控制字符( 即数值小于 0x20 的字符),则在该字符 前面要加入一个 0x7D 字节,同时将该字 符的编码加以改变。 零比特填充 nPPP 协议用在 SONET/SDH 链路时,是使用 同步传输(一连串的比特连续传送)。这时 PPP 协议采用零比特填充方法来实现透明传输 。n在发送端,只要发现有 5 个连续 1,则立即填 入一个 0。接收端对帧中的比特流进行扫描。 每当发现 5 个连续1时,就把这 5 个连续 1 后 的一个 0 删除, 0 1 0 0 1 1 1 1 1 0 1 0 0 0 1 0 1 00 1 0 0 1

15、1 1 1 1 1 0 0 0 1 0 1 00 1 0 0 1 1 1 1 1 0 1 0 0 0 1 0 1 0信息字段中出现了和 标志字段 F 完全一样 的 8 比特组合发送端在 5 个连 1 之后 填入 0 比特再发送出去在接收端把 5 个连 1 之后的 0 比特删除会被误认为是标志字段 F 发送端填入 0 比特接收端删除填入的 0 比特零比特填充不提供使用序号和确认 的可靠传输 nPPP 协议之所以不使用序号和确认机制是 出于以下的考虑:n在数据链路层出现差错的概率不大时,使用比 较简单的 PPP 协议较为合理。n在因特网环境下,PPP 的信息字段放入的数 据是 IP 数据报。数据链

16、路层的可靠传输并不 能够保证网络层的传输也是可靠的。n帧检验序列 FCS 字段可保证无差错接受。 4.3.3 PPP 协议的工作状态 n当用户拨号接入 ISP 时,路由器的调制解调器对 拨号做出确认,并建立一条物理连接。nPC 机向路由器发送一系列的 LCP 分组(封装成 多个 PPP 帧)。n这些分组及其响应选择一些 PPP 参数,和进行 网络层配置,NCP 给新接入的 PC机分配一个临 时的 IP 地址,使 PC 机成为因特网上的一个主 机。n通信完毕时,NCP 释放网络层连接,收回原来 分配出去的 IP 地址。接着,LCP 释放数据链路 层连接。最后释放的是物理层的连接。 PPP 协议的状态图 建立失败失败NCP 配置鉴别成功通信 结束载波 停止检测到载波双方协商 一些选项鉴别网络打开终止静止4.4 HDLC 协议n1974年,IBM 公司推出了面向比特的规程 SDLC (Sy

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号