数据链路层协议【MAC帧和ARP协议】

以太网帧格式

定义:

以太网是一种数据链路层和物理层标准,用于在计算机之间进行数据帧的传输。它基于多点总线传输方式,使用CSMA/CD(载波侦听多路访问/冲突检测)为媒体访问控制方法。

在这里插入图片描述

我们可以将以太网帧比喻为一封邮件:

  1. 前导码 (Preamble):这就像信封的封口纹理,当你摸到它时,你知道你即将打开一封信。

  2. 起始帧定界符 (SFD):这是你真正开始打开信封的地方,告诉你:“好了,邮件开始了。”

  3. 目的MAC地址:这是信封上写的收件人地址。它告诉邮递员这封信应该送到哪里。

  4. 源MAC地址:这是信封上的发件人地址,告诉你这封信来自哪里。

  5. 类型/长度:这就像信封上的邮票,告诉邮递员这是什么类型的信件(例如,是普通信件、快递还是特快专递),或者信的重量。

  6. 数据与填充:这是信封里的实际信件内容。有时,为了保护信件不被损坏或使其看起来更饱满,我们可能会在里面放一些填充物。

  7. 帧校验序列 (FCS):这就像信封底部的封条,如果它被撕破或损坏,说明信件在途中可能已经被打开或损坏。

将整个以太网帧想象为这样一封邮件,可以帮助我们更形象地理解每个部分的作用和重要性。

MAC地址

MAC地址,全称为"媒体访问控制地址"(Media Access Control Address),是一个网络设备在局域网中的唯一标识。它是一个12位的十六进制数,通常写作6个组,每个组2个字符,例如:00:1A:2B:3C:4D:5E

以下是关于MAC地址的一些要点:

  1. 固定和唯一:每个网络设备出厂时都被分配一个独特的MAC地址。这个地址在生产时被硬编码到设备上,也被称为"物理地址"或"硬件地址"。

  2. 分层:MAC地址是数据链路层(OSI模型的第2层)的地址。与IP地址(网络层地址)不同,MAC地址不是为了指定网络上的位置,而是为了标识网络上的物理设备。

  3. 制造商标识:MAC地址的前半部分是制造商的唯一标识,被称为组织唯一标识符(OUI)。这使得我们可以通过MAC地址推断出制造设备的公司。

  4. 广播地址:全F的MAC地址(FF:FF:FF:FF:FF:FF)是广播地址,发送到这个地址的数据包会被网络上的所有设备接收。

  5. 局域网内使用:MAC地址主要在局域网内使用,用于指导数据在网络内部如何流动。当数据离开局域网进入互联网时,它将依靠IP地址进行路由。

  6. 可变性:虽然每个网络设备都有一个固定的MAC地址,但许多现代设备允许用户更改或伪造MAC地址。

MAC地址是以太网和许多其他网络技术的基础。在一些网络操作中,例如ARP(地址解析协议),MAC地址被用来将网络层的IP地址映射到数据链路层的物理地址。

MAC地址和IP地址对比理解

MAC地址和IP地址的结构化对比:

特性MAC地址IP地址
定义网络接口卡(NIC)的唯一标识符网络上每个设备的逻辑地址
长度和格式12位十六进制数 (例如: 00:1A:2B:3C:4D:5E)IPv4: 32位 (例如: 192.168.1.1), IPv6: 128位
分层OSI模型的数据链路层(第2层)OSI模型的网络层(第3层)
变动性通常固定,但可伪造可以是静态或动态
范围局域网内部全球互联网
作用标识特定的物理设备确定网络上的逻辑位置
来源由设备制造商在生产时分配由网络管理员分配或由DHCP自动分配
可见性仅在本地网络内可见可在整个互联网上可见(除非位于NAT背后)

这种结构化的表示方法更容易为人们快速比较和理解两种地址的主要差异。

MTU

MTU (Maximum Transmission Unit)

定义:

MTU 是指在一个网络链接上可以发送的数据包的最大尺寸,不包括数据链路层的帧开销。换句话说,它是指不需要进行碎片化的数据包的最大长度。

查看硬件地址和MTU

在这里插入图片描述

细节:

  1. 大小: 默认的 Ethernet MTU 为 1500 字节。这意味着对于普通的 Ethernet 设备,任何大于1500字节的数据包都需要在传输前进行碎片化。

  2. 碎片化: 如果数据包的大小超过 MTU,则需要进行碎片化,以便通过网络进行传输。在目的地,这些碎片再次被组装成原始数据包。

  3. 问题: 如果 MTU 设置得过小,将导致更多的碎片化和增加的头开销。如果设置得过大,可能会导致数据包传输失败。

  4. 路径 MTU 发现: 路径 MTU 发现是一种机制,其目的是确定两个 IP 主机之间通信路径上的最小 MTU。这可以避免碎片化并优化网络传输。

  5. 应用: 在某些VPN或隧道协议中,可能需要减小MTU,因为这些协议会增加额外的头信息。

  6. 修改: 在大多数操作系统中,可以手动设置网络接口的 MTU,但通常建议使用默认值,除非有特定的需要。

为什么它重要:

MTU 对于网络性能至关重要。正确的 MTU 设置可以确保网络数据有效、高效地传输,而不会产生不必要的延迟或传输问题。不恰当的 MTU 设置可能导致网络性能下降或其他传输问题。

MTU对IP协议的影响

在这里插入图片描述

MTU(Maximum Transmission Unit)和IP协议之间有紧密的联系。MTU定义了在特定网络技术中,数据链路层可以承载的最大IP数据包大小,而不需要进行碎片化。以下是MTU对IP协议的一些主要影响:

  1. IP碎片化:

    • 当IP数据包的大小超过给定链接的MTU时,数据包必须被碎片化才能传输。
    • 在发送端,IP数据包被分解成更小的碎片,这些碎片独立地通过网络传输,并在接收端重新组装。
  2. 效率与性能:

    • 碎片化和重新组装过程会消耗额外的计算和网络资源,可能导致延迟。
    • 过多的碎片化可能会降低网络性能,因为每个碎片都需要独立的头信息,增加了总体传输的开销。
  3. 路径MTU发现:

    • 路径MTU发现是一种协议机制,用于确定两个IP端点之间的最小MTU。这有助于确保数据包在整个路径上不需要碎片化。
    • 如果路径中的任何链接的MTU小于数据包的大小,路由器通常会丢弃该数据包,并通过ICMP消息通知发送端。
  4. 可靠性问题:

    • 如果某个碎片在传输中丢失,整个原始数据包都可能需要重新发送。
    • 大量的碎片化可能增加丢包的风险。
  5. 安全问题:

    • 碎片化可以被用作网络攻击的一种手段,例如碎片化重叠攻击,其中攻击者发送重叠的IP碎片试图绕过安全设备。
  6. VPN和隧道:

    • 使用VPN或其他隧道技术可能需要减小MTU,因为这些技术为数据包添加了额外的头部。

总之,MTU对IP协议的工作方式、效率和安全性都有深远的影响。正确地管理和配置MTU可以确保网络数据的有效、高效和安全传输。

在这里插入图片描述

MTU对TCP和UDP的影响

MTU(Maximum Transmission Unit)指定了网络层最大可传输的数据单元。当数据需要在网络上进行传输时,它会受到该链接的MTU的限制。如果数据单元(例如TCP或UDP数据包)超过MTU,那么它会在IP层被碎片化。这对于传输层协议,特别是TCP和UDP,有以下影响:

  1. TCP的影响:

    • 自适应MTU:TCP通过路径MTU发现(PMTUD)机制,尝试确定两个端点之间的最小MTU,以避免碎片化。

    • 性能和吞吐量:如果TCP段大小(或MSS)不正确地配置,而超过路径的MTU,可能导致不必要的碎片化。这会增加延迟,降低吞吐量,并可能导致部分或全部TCP段在传输过程中丢失。

    • 拥塞控制:由于碎片化导致的数据包丢失,TCP拥塞控制算法可能错误地将其解释为网络拥塞的信号,从而导致窗口大小减小,降低传输速度。

    • 重传:如果一个碎片在传输过程中丢失,整个原始的TCP段可能都需要被重传,尽管其他碎片已成功到达。

  2. UDP的影响:

    • 不保证重新组装:与TCP不同,UDP不保证数据的传输。如果一个UDP数据包被碎片化,并且其中的一个碎片在传输过程中丢失,那么整个数据包都会被丢弃。UDP没有重传机制来处理这种情况。

    • 应用程序处理:考虑到UDP的这种特性,许多应用程序被设计为发送小于常见MTU值的数据包,例如1400字节,以避免碎片化。

    • 延迟:尽管UDP自身没有拥塞控制,但由于碎片化造成的延迟可能会影响UDP流量,特别是在实时应用程序如VoIP和在线游戏中。

  3. 其他注意事项:

    • 碎片化和防火墙/安全设备:许多安全设备不喜欢处理碎片化的数据包,因为它们可能被用来绕过检测。这可能导致碎片化的数据包被丢弃,从而影响TCP和UDP的可靠性和性能。

    • UDP碎片化攻击:由于UDP不进行重传,它可能更容易受到基于碎片化的DoS攻击。

综上所述,虽然MTU是一个网络层参数,但它对传输层协议,尤其是TCP和UDP,有直接的影响。理解这种影响并正确地配置MTU和相关参数是关键,以确保网络应用程序的最佳性能和可靠性。

ARP协议

ARP (Address Resolution Protocol) 是一个用于将32位的IP地址映射到物理地址(例如MAC地址)的协议。它是局域网内(尤其是在以太网环境中)不可或缺的协议,因为在数据链路层,通信是基于物理地址,也就是MAC地址进行的。

ARP数据报的格式

在这里插入图片描述

字段说明:

  1. 硬件类型 (HTYPE): 这个字段定义了正在使用的硬件类型。例如,以太网的值是1。

  2. 协议类型 (PTYPE): 这个字段定义了操作的上层协议。例如,IPv4的值是0x0800。

  3. HLEN: 硬件地址长度。对于以太网,这个值是6。

  4. PLEN: 协议地址长度。对于IPv4,这个值是4。

  5. 操作码 (OPER): 定义操作类型,1表示ARP请求,2表示ARP响应。

  6. 发送者硬件地址 (SHA): 发送方的硬件地址(通常是MAC地址)。

  7. 发送者协议地址 (SPA): 发送方的协议地址(通常是IP地址)。

  8. 目标硬件地址 (THA): 目标的硬件地址。对于ARP请求,这个字段通常被设置为0,因为发送方正在查找这个地址。

  9. 目标协议地址 (TPA): 目标的协议地址。这是发送方想要知道的硬件地址对应的IP地址。

ARP协议的作用

  1. 解析地址:ARP允许网络设备(如计算机、路由器)在拥有一个目标IP地址的情况下,查询该IP地址对应的MAC地址。这是实现IP网络上的通信的关键,因为在数据链路层,信息是基于MAC地址发送的。

  2. 维护ARP缓存:为了提高通信效率,每个网络设备都维护了一个ARP缓存或ARP表。这个表包含了近期解析的IP地址和对应的MAC地址的映射。通过使用这个缓存,设备可以快速地找到一个已知的IP地址的MAC地址,而无需再次发送ARP请求。

  3. 动态学习:当设备收到一个ARP请求或响应时,它会更新其ARP缓存,从而学习新的IP到MAC的映射。这种动态学习机制使得ARP能够适应网络拓扑的变化。

  4. 广播请求,单播响应:当设备需要解析一个IP地址时,它会广播一个ARP请求到整个局域网。只有拥有该IP地址的设备会响应该请求,发送一个包含其MAC地址的ARP响应。这个响应是单播的,只发送给发起请求的设备。

  5. 防止地址冲突:在某些网络配置场景中,ARP还可以被用来检测IP地址冲突。例如,如果一个设备配置了一个静态IP地址,并在网络上广播一个ARP请求查询这个地址,但接收到了一个响应,这意味着网络上有其他设备使用了同样的IP地址,从而导致地址冲突。

总的来说,ARP是IP网络中的核心协议,它为IP通信提供了必要的地址解析机制。

ARP协议的工作流程

在这里插入图片描述

ARP协议的工作流程主要涉及到地址解析和维护ARP缓存表。以下是ARP协议的基本工作流程:

  1. ARP请求

    • 当主机A想要与同一局域网上的主机B通信,但不知道主机B的MAC地址时,主机A会在网络上广播一个ARP请求。
    • 这个ARP请求包含:发送者的IP和MAC地址(主机A的地址),以及目标的IP地址(主机B的地址)。
    • ARP请求实际上是在询问:“谁拥有这个IP地址,可以告诉我你的MAC地址吗?”
  2. ARP响应

    • 局域网上的所有主机和设备都会收到这个ARP请求,但只有目标IP地址匹配的主机(在这里是主机B)会响应。
    • 主机B会发送一个ARP响应给主机A。这个响应包含:发送者的IP和MAC地址(主机B的地址)。
    • 这个ARP响应实际上是在告诉主机A:“我拥有这个IP地址,这是我的MAC地址。”
  3. 更新ARP缓存

    • 当主机A收到ARP响应后,它会更新其ARP缓存表,添加或更新主机B的IP地址和对应的MAC地址的条目。
    • 为了减少网络上的ARP请求的数量,ARP缓存表中的条目通常会被保留一段时间。但如果长时间不使用,这些条目可能会过期并被删除。
  4. 直接通信

    • 一旦主机A知道了主机B的MAC地址,它就可以开始使用这个地址在数据链路层进行通信。
  5. 地址冲突检测

    • 在某些情况下,ARP也用于地址冲突检测。例如,如果主机A试图配置一个IP地址,它可能首先会在网络上发送一个ARP请求,看看是否有其他设备响应。如果有设备响应,这意味着这个IP地址已经被其他设备使用,从而产生了地址冲突。
  6. ARP欺骗/ARP欺诈

    • 虽然ARP是一个非常有用的协议,但它也容易受到攻击,尤其是ARP欺骗攻击。在这种攻击中,攻击者发送伪造的ARP响应,试图使网络上的设备相信攻击者的MAC地址与某个IP地址相关联。这可以用来执行中间人攻击或其他网络攻击。

总之,ARP协议在局域网内通过简单的请求-响应机制实现IP地址到MAC地址的映射,使得基于IP的通信成为可能。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_featherbrain

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值