为了更好地促进互联网络的研究和发展,国际标准化组织 ISO 在 1985 年制定了网络互连模型,OSI 参考模型(Open System Interconnect Reference Model),具有 7 层结构。然而OSI参考模型仅仅是理论模型,真正应用过程中用得最多的其实是TCP/IP 协议模型,而学习研究时通常则是五层

这五层结构每一层都有一套处理数据包的机制,其处理方式和对应的协议则大致如下图所示:


在物理层,数据是以信号的方式被传输,根据网络范围分为模拟信号和数字信号
模拟信号:连续的信号,适合长距离传输,抗干扰能力差,受到干扰时波形变形很难纠正

数字信号:离散的信号,不适合长距离传输,抗干扰能力强,受到干扰时波形失真可以修复

在不同的网络通信范围内,对应的网络通信模型如下:



信道就是信息传输的通道,由发射端传输到接收端所经过的传输媒质所构成,在同一条传输介质(如网线)上可以有多条信道(例如计算机0可以发送数据给计算机1,计算机1也可以发送数据给计算机0)
从1个节点到相邻节点的一段物理连接(有线或无线),且中间没有其他交换节点,被称之为链路。在一条链路上传输数据时,需要有对应的通信协议来控制数据的传输,而不同类型的数据链路,所用的通信协议可能是不同的。
常见的有:
接下来看如下例图:

从图中可以看出,圈出来的每一部分就代表着一段数据链路
数据链路层有三个特点:
封装成帧

该特点就是将IP层传下来的数据包加上首部和尾部,封装成帧,而首部和尾部中又包含帧开始符和帧结束符,同时帧的数据部分(IP层数据包)有一个最大值MTU(Maximum Transfer Unit)限制,不能超过这个值。通常在我们日常用的以太网(采用CSMA/CD协议)中的MTU为1500个字节
透明传输

在将IP层数据包封装成帧时,帧开始符用SOH代表,帧结束符用EOT代表,然而当数据部分也出现两个符号时,就会出现问题。因此解决方式就是将数据中的特殊符号进行转义

差错校验

数据链路层的帧由帧首部、帧尾部、帧数据三个部分组成,而帧首部中又包含数据链路层首部和帧开始符,帧尾部包含FCS和帧结束符。其中FCS是根据数据链层首部和帧的数据部分算出来的,接受方需要对这个值进行校验,目的是为了防止数据在传输过程中出现变动,一旦发现数据对不上,网卡会直接把数据给丢弃
以上三个特点不管走的什么协议,都会去实现。接下来就看一下每个协议的具体实现
CSMA/CD协议全称是Carrier Sense Multiple Access with Collision Detection(载波侦听多路访问/冲突检测),字面意思解释就是
使用了CSMA/CD协议的网络可以称为是以太网,其传输的是以太网帧,以太网帧的格式有Ethernet V2标准、IEEE的802.3标准,通常使用最多的是Ethernet V2标准。同时为了检测正在发送的帧是否发生了冲突,以太网的帧最少需要64个字节(可以参考这个回答)
需要注意的是,用交换机组成的网络已经支持全双工通信,不需要再使用CSMA/CD协议,但它传输的帧依旧是以太网帧
下面图就是以太网帧的格式

从图中可以看出,首部是由目标MAC地址、源MAC地址、类型组成,MAC帧则是由首部、数据、FCS组成。由于MAC帧至少是64字节,因此数据部分至少要46字节(64-6-6-2-4),当数据部分的长度小于46字节时,数据链路层会在数据的后面加入一些字节填充,到接收端时会将添加的字节去掉。当在物理层时,以太网MAC帧前面还会加上8个字节的数据(7个字节的前同步码和一个字节的帧开始符)
在上图中会发现MAC帧没有前面所说的帧结束符,这是因为以太网使用曼彻斯特编码,在传送帧时,各帧之间必须有一定的间隙,接收端只要找到帧开始定界符,其后面连续到达的比特流就都属于同一个MAC帧

因此可以看出以太网帧的数据长度是46 ~ 1500字节,而以太网帧的长度是64 ~ 1518字节
下图就是PPP帧的格式

Wireshark是一款用来抓包的工具,在通过抓包对帧格式分析后,会发现Wireshark抓到的Ethernet V2帧没有FCS字段

其实这是因为网卡的原因,网卡在接受到一个帧时,首先会进行差错校验,如果校验通过则被接受,否则丢弃。而Wireshark抓到的就是差错校验通过的帧(帧尾的FCS会被去掉)。
以下是网卡在物理层和数据链路层的具体功能
