信道类型:
- 点对点:即一对一的通信(重点学习)
- 广播:即一对多通信。
一、链路层的几个共同问题
1、数据链路和帧
数据链路
首先要明确一下,"链路(也叫物理链路)"和"数据链路(也叫逻辑链路)"不是同一个东西。链路是指从一个节点到相邻节点的一段物理线路(有限或无线),二者中间没有任何其他的交换节点。数据在传输的时候需要一些协议来控制,数据链路就是链路+实现协议的硬件和软件。一般用网络适配器来实现这些协议,一般的适配器都包含链路层和网络层这两层的功能。
帧
链路层的PDU(Protocol Data Unit)就是帧,链路层就是把网络层下来的数据封装成帧发送到链路上,以及把收到的帧中的数据取出并上交给网络层。网络层的PDU就是IP数据报(简称为数据报、分组或包)。
链路层点对点通信步骤
- A把网络层给下来的IP数据报添加首部尾部封装成帧
- A把帧发送给B的链路层
- B检查帧无差错后取出IP数据报上交给网络层,若有差错,则丢弃
2、三个基本问题
链路层的协议有很多中,但协议中都要考虑这三个问题:封装成帧、透明传输、差别检测
封装成帧
就是在一段数据的前后分别加上首部和尾部,就构成了一个帧。首部和尾部的一个重要作用就是帧定界(确定帧的界限)。为了提高帧的传输效率,应当使数据部分的长度尽可能大鱼首部和尾部的长度,但是,每一种链路层的协议都规定了MTU(Maximun Transfer Unit),使得数据部分<=MTU。
当数据是由ASCII码组成的文本时,帧定界可以用特殊的帧定界符。由于ASCII码是7位,可以组成128个ASCII码,可打印的有95个,不可打印的有33个我们可用不可打印的ASCII码来代表开始与结束。字符SOH(Start Of Header)放在一帧的最前面,其二进制是00000001,EOT(End Of Transmission)放在一帧的最后,其二进制是00000100。
当数据传输中出现差错时,帧定界符的作用更加明显,例如发送端发送一个帧时突然故障,没有发送完,随后很快恢复正常,有从新发刚刚那个没发完的帧。接受端第一次由于没有见到EOT,所以丢弃第一个帧,之后发过来的有SOH和EOT,就正常接收了。
透明传输
透明:某一个实际存在的事物看起来却好像不存在一样(就像你看不见在你面前有块100%透明的玻璃的存在)
在链路层透明传送数据,表示无论什么样的比特组合而成的数据,都能原模原样的传给对方。但是,如果数据中有EOT或SOH,就会出现提前结束之类的问题,就不叫透明传输了。为了解决这个问题,我们采取加入ESC转义字符的方法:若是说数据部分中出现SOH,就在这个SOH前面插入一个ESC(二进制是00011011),而在接受端的链路层把数据送往网络层之前删除这个插入的转义字符。这种方法叫做字符填充。如果ESC也出现在数据中,那么解决方法也是在其前面插入一个ESC。因此,接受端收到连续的两个转义字符事,就删除前面的那一个。
差错检测与纠正
信息在传的过程中可能会出现差错,比如把1传成0,这叫比特差错。为了保证数据的正确性,就需要采取差错检测措施:
- 奇偶校验
- 二维奇偶校验
- 校验和校验
- 循环冗余校验(CRC)
以上几种方法均只能保证帧的内容无差错,但却并不能保证另外一类差错:帧丢失、帧重复、帧失序。为了应对这一类差错,互联网采取了区别对待的方法:对于通信质量好的有线传输链路,不要求链路层向上层提供可靠的服务,改正差错的任务就交给上层(如传输层的TCP协议),对于通信质量不好的无线传输链路,数据链路层需要向上层提供可靠的服务。事实证明,这样可以提高通信效率
二、点对点协议PPP(point to point protocol)
1、PPP协议的特点
ppp协议是用户计算机和ISP进行通信时所使用的数据链路层协议,实现在使用的最广泛的链路层协议。PPP协议是IETF在1992年制定的现在的PPP协议在1994年就已经成为互联网的正式标准了
PPP协议应满足的要求
- 简单。IETF把复杂的部分放在了TCP协议中,链路层只需要完成简单的功能就可以了。IETF把"简单"作为首要的需求
- 封装成帧。PPP协议必须规定特殊的自负作为帧定界符,以便快速地找出帧的开始与结束的位置
- 透明性。必须保证数据传输的透明性
- 多种网络层协议。PPP协议必须能够在同一条物理链路上同时支持多种网络协议(如IP和IPX等)的运行
- 多种链路类型。如,串行的或并行的,同步的或异步的,低速的或高速的的等等点对点链路
- 差错检测。要能够对收到的数据进行检测,并立即丢掉有差错的帧。
- 检测连接状态。必须有一种机制能够自动检测出链路是否处于正常工作状态
- 最大传送单元。对每一种链路设置最大传送单元
- 网络层地址协商。必须提供一种极致使通信的两个网络层实体能够通过协商知道彼此的网络层地址
- 数据压缩协商。必须提供一种方法来协商使用数据压缩算法
PPP协议的组成
- 一个将IP数据报封装到串行链路的方法
- 一个用来建立、配置和测试数据链路连接的链路控制协议LCP
- 一套网络控制协议NCP,其中每一个协议支持不同的网络层协议
2、PPP协议的帧格式
各字段的意义
如图所示,头部有4个字段(F、A、C、协议),尾部有两个字段(FCS、F)。
其中的F(flag)为标志字段,二进制为01111110,表示一个帧的开始或结束。因此标志子段就是PPP帧的定界符。连续两个帧之间只需要一个F。
首部中的A和C使最初曾考虑以后再对这两个字段的值进行其他定义,但至今也没有给出。所以A和C啥也不是。
协议字段为0x0021时,帧的信息部分就是IP数据报。若为0xC021,则信息部分是LCP的数据,而0x8021表示这是网络层的控制数据
信息字段的长度是可变的,不超过1500字节
尾部的第一个字段时使用CRC的帧检验序列FCS
字节填充
当信息字段中出现和标志字段一样的比特时,就要在其前面加上转义字符。PPP中的转义字符为0x7D(即01111101)在接受端会自动识别并去除这些转义字符。
零比特填充
当使用同步传输(一连串的比特连续传送)而不是异步传输(逐个字符地发送),PPP采取零比特填充实现透明传送
核心思想:由于标志字段F的二进制为01111110,有6个连续的1,因此只要对信息部分有连续5个1的后面插入一个0,就可以了。插入的0在接受端识别完边界后去除。
3、PPP协议的工作状态
PPP链路的初始化:当用户拨号接入ISP后,电脑就向ISP发送一系列的LCP分组(封装成多个PPP帧),这些分组选择了将要使用的一些PPP参数。然后是进行网络层配置,NCP会给新接入的电脑分配一个临时IP,这样,用户的电脑就成为互联网上的一个有IP的主机了。
通信结束后,NCP释放网络层连接,收回分配的IP,然后LCP释放链路层连接,最后释放的是物理层的连接
三、使用广播信道的数据链路层
1、局域网的链路层
局域网的特点:为一个单位所拥有,地理范围和站点有限
优点:
- 具有广播功能,从一个站点可以很方便的访问全网
- 便于系统的拓展,各设备的位置可以灵活改变
- 提高了系统的可靠性、可用性和生存性
按照拓扑结构可分为星形、环形和总线形,如下图所示
星形用的使用较多,集线形中的匹配电阻是为了避免总线上产生有害的电磁波反射
共享信道要着重考虑的一个问题就是如何使众多用户合理而方便地共享通信媒体资源,这在技术上有两类方法:
一、静态划分信道
即频分、时分、波分、码分复用,但是代价较高,不适合用于局域网
二、动态媒体接入控制(多点接入)
随机接入、受控接入
受控接入使用的较少,所以本文重点讨论随机接入。
适配器:计算机与外界局域网的链接是通过适配器(简称“网卡”,包括RAM和ROM)来完成的。由于适配器和局域网之间是通过串行传输方式进行,与计算机是通过I/O总线以并行传输方式进行的。因此,它的一个重要功能就是数据串行传输和并行传输的转换。由于传输速率不同,因此还要配上进行缓存的存储芯片。另外还要把管理该适配器的驱动安装在计算机的操作系统中,用于对适配器的控制。适配器还要能够实现以太网的协议。
特别要注意,计算机的硬件地址在适配器的ROM中,计算机的软件地址----IP,在计算机的存储器中
2、CSMA/CD(载波监听多点接入/碰撞检测)协议
在总线上进行一对一通信的实现:使每一个适配器都有一个独一无二的地址,发送数据帧时,在首部写明目的地址,仅当目的地址与适配器ROM中存放的的硬件地址一样时,适配器才接收,否则,丢弃。
为了通信的简便,以太网采取了以下两种措施:
1.发送的数据用曼彻斯特编码的信号
2.无连接的工作方式
不可靠,只能尽力,对出现差错的帧是否重传由高层来决定。如果重传了,以太网也并不知道这是重传的,而是当作新的帧来发送。
同一时间只能允许一台计算机发送数据
下面介绍CSMA/CD协议的要点
电磁波在1km电缆的传播时延约为5μs
多点接入:多个计算机接到一根总线上
协议的实质就是载波监听和碰撞检测
载波监听:不管是在要发数据之前,还是在发送数据中,每个站都必须不停地检查信道
碰撞检测:发现有其他站在发送,就不发送或者停止发送
使用CSMA/CD协议的以太网只能进行双向交替信道,因为一个站不能同时进行发送和接受(那样的话就会发生碰撞)
每一个站在自己发送数据之后的一小段时间内,存在着遭受碰撞的可能性,这一小段时间取决于离接收站的距离。这被称为发送的不确定性
争用期(51.2μs):单程端到端的传播时延为τ,发送数据后最多经过2τ(σ->0时)就可以知道是否发生了碰撞,2τ就叫争用期,过了争用期还没有发现碰撞,才能断定发送成功
一般在检测到碰撞之后需要等待随机的时间后再进行检测和发送,随机时间采用截断二进制指数退避
以太网规定了一个最短帧长64字节,即512bit,如果发送的数据太少,就必须加入一些填充字节,使帧长不小于64字节,若小于,则丢弃。对于10Mbit/s以太网,发送512bit的时间需要51.2μs,也就是上面提到的争用期。
下面介绍强化碰撞的概念
发送数据的站一旦检测到了碰撞,除了立即停止发送数据,还会发送32bit或者48bit的人为干扰信号,让所有站都知道现在发生了碰撞
以太网还规定了帧间最小间隔为9.6μs,相当于96bit时间,这是为了使刚刚收到帧的站处理好接收到的数据。
综上述,CSMA/CD协议的要点如下
1.准备发送:发送之前要检测信道
2.检测信道:若检测到信道忙,则继续检测,一直等待信道转为空闲。此时若再96bit时间内仍未空闲,就发送这个帧
3.网络适配器在发送帧时要边发送边监听
每发送完一个帧,一定要把这个帧暂时保留一下,如果在争用期内发生了碰撞,那么就推迟一段时间后再重传这个暂时保留的帧
3.使用集线器的星行拓扑
性价比很高,是局域网发展史上的一个重要里程碑。集线器的一些特点如下:
1.使用集线器的以太网在逻辑上仍是一个总线网,各站共享逻辑上的总线,使用的还是CSMA/CD协议,在同一时刻至多只允许一个站点发数据。
2.一个集线器有许多端口
3.集线器工作在物理层,仅仅转发比特,不进行碰撞检测
4.集线器采取了专门的芯片,进行自适应串音回波抵消
4、以太网的信道利用率
由于碰撞的存在,以太网的信道利用率并不能达到100%
成功发送一个帧所需要占用信道的时间为=发送的时间T0+τ。
定义a=τ/T0,当a->0时,表示只要易发生碰撞,就立马检测出来。反之,a越大,表明争用期占用比例越大,信道利用率就越低。因此,a要尽可能小,因此以太网的连线长度受限制(否则τ会大),帧长不能太短(否则T0会太小)
理想情况下,极限信道利用率为T0/(T0+τ)=1/(1+a)
5、以太网的MAC层
MAC层的硬件地址
适配器的ROM中的地址是硬件地址,也叫物理地址或者MAC地址,由48位,即个字节组成。MAC地址是与适配器绑定的。前24位需要向IEEE的机构RA购买,后24位由买家自己定,知道没有重复的就行。可见一个地址块可以生成2的24次方个地址。第8位为I/G位,为0时,地址字段代表一个单个站地址。为1时,表示组地址,用来进行多播,第7位为G/L位,为0时,代表全球管理,1时代表本地管理。因此,对每一个站的地址可用46为二进制数来表示。MAC地址如果48为全是1,那么就是一个广播地址,即所有人都可以接收
MAC帧的格式
下面介绍V2的MAC帧格式
组成:
- 目的地址:即MAC地址,6字节
- 源地址;即MAC地址,6字节
- 类型;用来标志上一层所使用的是什么协议,2字节
- 数据:前面提到帧最小为64字节,MTU为1500,因此数据最小为(64-(6+6+2+4))=46字节
- FCS:用来差错检测,4字节
不用标志字段:
由于以太网发送使用的是曼彻斯特编码,各个帧之间有一定的空隙,因此接收方可以很容易找到尾部和头部,在尾部往前4个字节,就能确定数据字段的结束位置了。
填充字段:
数据字段少于46字节时,就会在数据后面加入一个填充字段。由于上层使用IP协议时,首部有一个总长度,可以根据这个在上层发现并去除填充字段。
前同步码和帧开始定界符:
前同步码的作用就是调整接收端的时钟周期使其与发送端一样。帧开始定界符的作用就是给适配器说一下,帧要来了,让它做好准备
不负责重传:
对于检查出错误的MAC帧就简单地丢弃,不负责重传