以太网协议、ARP协议、NAT协议、DNS协议

以太网协议、ARP协议、NAT协议、DNS协议目录 1 数据链路层的以太网协议 2 ARP 协议 1 数据链路层的以太网协议数据链路层的以太网协议本质上其实就是相邻设备之间的数据转发 以太网协议格式 MAC 地址 每一个网卡设备在出厂的时候都会拥有一个全球独一无二的 MAC 地址 MAC 地址也被称为硬件的地址 本质上是 6 字节的整数 即 uint8 taddr 6 可以在 ifconfig LINUX 中查看到对应的 MAC 地址 Windows 中可以使用 ipconfig all 进行查看以太网格式中的类型 2 位 表示的是上层


1. 数据链路层的以太网协议

数据链路层的以太网协议本质上其实就是相邻设备之间的数据转发

以太网协议格式:

在这里插入图片描述

MAC地址:每一个网卡设备在出厂的时候都会拥有一个全球独一无二的MAC地址,MAC地址也被称为硬件的地址。

以太网格式中的类型(2位):

表示的是上层使用了什么协议 (ip / ARP协议)。

有效载荷:[46 ~ 1500]字节

如果网络层递交给数据链路层的数据不够46字节,则会对数据进行相应补0的操作。1500字节刚好是MTU(最大传输单元)的上限。

CRC

校验帧尾,检验数据在传输过程中是否失真。

2. ARP协议

上面其实我们也谈到了以太网协议格式,我们可以看到格式中的目的地址和源地址指的是目的MAC地址和源MAC地址,换句话说,数据在数据链路层进行发生的时候,需要知道目标主机MAC地址,但是网络层的协议递交给数据链路层的数据仅仅包含目标主机的ip地址,我们无法获知其对应的MAC地址,那么,我们该如何获取目标主机的MAC地址呢?

换句话说:

  • 在网络通讯时,源主机的应用程序知道目的主机的IP地址和端口号,却不知道目的主机的硬件地址。
  • 数据包首先是被网卡接收到再去处理上层协议的,如果接收到的数据包的硬件地址与本机不符,则直接丢弃。
  • 因此在通讯前必须获得目的主机的硬件地址。

ARP协议就是用来解决此类问题的,他可以通过ip地址获取对应的MAC地址

注意:这里的ip地址本质上是通过路由项计算出来的接下来该条数据该去往的ip地址,而不是自己本身该去的ip地址。

因此,可以说ARP协议是介于网络层和数据链路层之间的协议,话句话来说就是ARP协议建立了主机 IP地址 和 MAC地址 的映射关系

ARP数据报格式

在这里插入图片描述

首先我们来看一下以太网首部的格式

  • 以太网目的地址:在ARP请求中,目的MAC地址填充为:0xFFFFFFFF,表示当前这条数据给子网当中的每一条机器都进行转发。
  • 以太网源地址:就是源MAC地址,就是当前主机的MAC地址。
  • 帧类型:上级协议(ARP协议)

28字节ARP请求/应答

  • 硬件类型:当前的网络类型:以太网、令牌环网。
  • 协议类型:要转换的地址类型,ip转换为MAC。
  • 硬件地址长度:表示MAC地址长度。
  • 协议地址长度:表示ip地址长度。
  • op:标识是请求还是应答

那么ARP又是如何知道MAC地址的呢?简单地说,ARP是借助ARP请求与ARP响应两种类型的包确定MAC地址的。

假定主机A向同一链路上的主机B发送IP包,主机A的IP地址为172.20.1.1,主机B的IP地址为172.20.1.2,它们互不知道对方的MAC地址。

在这里插入图片描述

主机A为了获得主机B的MAC地址,起初要通过广播发送一个ARP请求包。这个包中包含了想要了解其MAC地址的主机IP地址。也就是说,ARP请求包中已经包含了主机B的IP地址172.20.1.2由于广播的包可以被同一个链路上所有的主机或路由器接收,因此ARP的请求包也就会被这同一个链路上所有的主机和路由器进行解析。如果ARP请求包中的目标IP地址与自己的IP地址一致,那么这个节点就将自己的MAC地址塞入ARP响应包返回给主机A

总之,从一个IP地址发送ARP请求包以了解其MAC地址(ARP请求包还有一个作用,那就是将自己的MAC地址告诉给对方),目标地址将自己的MAC地址填入其中的ARP响应包返回到IP地址。由此,可以通过ARP从IP地址获得MAC地址,实现链路内的IP通信。

根据ARP可以动态地进行地址解析,因此,在TCP/IP的网络构造和网络通信中无需事先知道MAC地址究竟是什么,只要有IP地址即可。

ARP缓存表

如果每发送一个IP数据报都要进行一次ARP请求以此确定MAC地址,那将会造成不必要的网络流量,因此,通常的做法是把获取到的MAC地址缓存(是指预见到同样的信息可能会再次使用,从而在内存中开辟一块区域记忆这些信息) 一段时间。即把第一次通过ARP获取到的MAC地址作为IP对MAC的映射关系记忆(记录IP地址与MAC地址对应关系的数据库叫做ARP表) 到一个ARP缓存表中,下一次再向这个IP地址发送数据报时不需再重新发送ARP请求,而是直接使用这个缓存表当中的MAC地址进行数据报的发送。每执行一次ARP,其对应的缓存内容都会被清除。不过在清除之前都可以不需要执行ARP就可以获取想要的MAC地址。这样,在一定程度上也防止了ARP包在网络上被大量广播的可能性。

当然ARP是有老化时间的,老化时间为20min,会进行相应的更新。

arp协议只能在子网内部使用,只能给子网内部的机器进行广播arp请求。换句话说,只能获取子网内部机器的MAC地址

那么问题来了,IP地址和MAC地址缺一不可吗?

主机A想要发送IP数据报给主机B时必须得经过路由器C。即使知道了主机B的MAC地址,由于路由器C会隔断两个网络,还是无法实现直接从主机A发送数据报给主机B。此时,主机A必须得先将数据报发送给路由器C的MAC地址C1。

在这里插入图片描述
如此看来,IP地址和MAC地址两者缺一不可。于是就有将这两个地址相关联的ARP协议(为了避免这两个阶段的通信带来过多的网络流量,ARP具有对IP地址和MAC地址的映射进行缓存的功能。有了这个缓存功能,发送IP包时就不必每次都发送ARP请求,从而防止性能下降)。

3. NAT协议

NAT也叫地址转换协议

他的作用是:

  • 私网对公网请求的时候:将网络数据当中的私网的源ip地址转化成为公网的ip地址。
  • 公网对私网的应答:将网络数据当中的公网的目的ip地址转化成为私网的ip地址。
  • 静态NAT:NAT协议,将一个私网和一个公网唯一进行映射管理。
  • 动态NAT:NAT管理的不止是一个公网ip,当私网数据到来的时候,选择一个空闲的ip进行映射。

NAT的工作机制:

如上图,以10.0.0.10的主机与163.221.120.9的主机进行通信为例。利用NAT,途中的NAT路由器将发送源地址从10.0.0.10转换为全局的IP地址(202.244.174.37)再发送数据。反之,当包从地址163.221.120.9发过来时,目标地址(202.244.174.37)先被转换成私有IP地址10.0.0.10以后再被转发(在TCP或UDP中,由于IP首部中的IP地址还要用于校验和的计算,因此当IP地址发生变化时,也需要相应地将TCP、UDP的首部进行转换)

总结一下就是:不管是静态NAT还是动态NAT,都没有缓解ipv4枯竭的问题,本质上还是一个私网IP一定要对应一个公网ip,才能访问互联网。

NAPT协议(动态NAT重载)

在进行私网ip转化为公网ip的时候,不仅仅将ip地址转换掉了,并且还将传输层的端口也转换掉了。

注:在使用TCP或UDP的通信当中,只有目标地址、源地址、目标端口、源端口以及协议类型(TCP还是UDP)五项内容都一致时才被认为是同一个通信连接。此时所使用的正是NAPT。

在NAPT的场景下,一个公网ip,理论上最大可以转换多少个私网ip?

216 = 65536个,即 0 ~ 65535。

对NAT协议的总结:

  • NAT网关对于私网主机和公网主机而言,是透明的,双方在通信过程中是无感知的。
  • NAT网关会保存转换之后的映射关系,防止应答回来之后再次进行转换。
  • 私网 =》公网:是将网络数据当中的源ip地址修改为公网ip地址。
    公网 =》私网:是将网络数据当中的目的ip地址修改成为私网ip地址。
  • NAPT增加了端口的转换,就可以让一个公网ip服务多个私网主机。缓解了ip地址枯竭的问题
  • 数据只能先从私网到公网,不能从公网到私网。

4. DNS协议

DNS协议本身是应用层的协议,并且在传输层使用的UDP协议。也叫域名解析协议,他的作用就是将域名解析为ip地址。

域名:

一级域名:.com.cn.gov.us
二级域名:baidu.comjd.comtaobao.com
三级域名:baike.baidu.com

域名服务器:

域名解析的流程:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/216240.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午12:14
下一篇 2026年3月18日 下午12:14


相关推荐

  • pycharm将python程序打包_python 程序打包

    pycharm将python程序打包_python 程序打包关于使用Pycharm对python文件进行打包首先建立python项目的时候要按照标准来建设我使用的python配置的解释器,没有使用python的虚拟环境,因为虚拟环境建设出来的项目不是我想要的项目结构,包结构比较多,看着不是很舒服4.配置完成后点击创建创建完成后可以自己创建合适包结构创建完合适的包结构后,就可以编写python代码了,但要python代码运行开,需要配置运行环境9.环境配置调试好就可以运行调试python代码..

    2022年8月26日
    7
  • linux scp命令使用详解

    linux scp命令使用详解Linuxscp 命令一 前言二 语法三 实例 1 从本地复制到远程 1 命令格式 2 应用实例 3 复制目录命令格式 2 从远程复制到本地一 前言 Linuxscp 命令用于 Linux 之间复制文件和目录 scp 是 securecopy 的缩写 scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令 scp 是加密的 rcp 是不加密的 scp 是 rcp 的加强版 windows 系统下也可以使用 scp 命令 因此我们可以使用 scp 在 linux 与 windos 系统上互相传递文

    2026年3月18日
    2
  • vue动态引入js文件的方法_vue如何引入js文件

    vue动态引入js文件的方法_vue如何引入js文件Vue动态引入JS文件

    2022年10月8日
    6
  • Cursor + Claude 3.7 神奇组合:两步从原型到产品,轻松开发你的第一个App

    Cursor + Claude 3.7 神奇组合:两步从原型到产品,轻松开发你的第一个App

    2026年3月16日
    2
  • Py之Kivy:Python库之Kivy的简介、安装、使用方法之详细攻略

    Py之Kivy:Python库之Kivy的简介、安装、使用方法之详细攻略Py 之 Kivy Python 库之 Kivy 的简介 安装 使用方法之详细攻略目录 Kivy 的简介 Kivy 的安装 Kivy 的使用方法 Kivy 的简介 Kivy 是一套基于 Python 编写的类似安卓界面风格的界面库 它支持 Windows Linux Android 和 MacOS 四大主流平台绝大部分操作系统 而且界面风格能够在多平台之间保持一致 Kivy 依赖许多 Python 库 例如 pygame gstreamer PIL Cario 等等 它们并不总是必须的 Kivy 是

    2026年3月19日
    2
  • DB破解(暗黑破坏神辅助)使用方法「建议收藏」

    DB破解(暗黑破坏神辅助)使用方法「建议收藏」下载网址:http://www.mochafuzhu.com/forum.php?mod=forumdisplay&fid=57开始请先在网站里下载运行环境并安装,然后下载辅助。(Q群:528411948)1、首先,一定要先 启动游戏,注意!辅助的路径千万不要有中文的目录,否则会造成辅助自动退出的问题。然后解压下载好辅助后,我们得到以下画面,以管理员身份运行打开。(如果不能打开请检…

    2022年5月5日
    70

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号