【计算机网络】数据链路层--以太网/MTU/ARP/RARP协议

文章目录

  • 一、以太网
    • 1.以太网帧格式
    • 2.MAC地址
    • 3.局域网的转发原理
  • 二、MTU
    • 1.什么是MTU
    • 2.MTU对IP协议的影响
    • 3.MTU对UDP影响
    • 4.MTU对于TCP协议的影响
  • 三、ARP协议
    • 1.ARP协议的作用
    • 2.ARP数据报的格式
    • 3.ARP协议的工作流程

一、以太网

“以太网” 不是一种具体的网络, 而是一种技术标准; 既包含了数据链路层的内容, 也包含了一些物理层的内容. 例如: 规定了网络拓扑结构, 访问控制方式, 传输速率等;

例如以太网中的网线必须使用双绞线; 传输速率有10M, 100M, 1000M等;

以太网是当前应用最广泛的局域网技术; 和以太网并列的还有令牌环网, 无线LAN等;

1.以太网帧格式

以太网的帧格式如下所示:

在这里插入图片描述

源地址和目的地址是指网卡的硬件地址(也叫MAC地址), 长度是48位,是在网卡出厂时固化的;

帧协议类型字段有三种值,分别对应IP、ARP、RARP;

帧末尾是CRC校验码。

如何进行分离,如何分用?

以太网的MAC报头,采用定长的方式,我们就可以提取目的地址,源地址以及类型等信息,就可以实现分离和分用。

2.MAC地址

MAC地址用来识别数据链路层中相连的节点;

长度为48位, 即6个字节. 一般用16进制数字加上冒号的形式来表示(例如: 08:00:27:03:fb:19)

在网卡出厂时就确定了, 不能修改. mac地址通常是唯一的(虚拟机中的mac地址不是真实的mac地址, 可能会冲突; 也有些网卡支持用户配置mac地址)。

对比理解MAC地址和IP地址

IP地址描述的是路途总体的 起点 和 终点;

MAC地址描述的是路途上的每一个区间的起点和终点;

3.局域网的转发原理

跨网络传输的本质就是由无数个局域网(子网)转发的结果。要理解跨网络转发,首先要理解局域网中报文的转发原理。

在同一个局域网的主机,能够直接进行通信,并且每一台主机都有唯一的标识符–每张网卡都有唯一的一个sn,该网卡的mac地址,在全球范围内具有唯一性。

在局域网通信中,要进行通信的主机在mac报文中填入目的mac地址,源mac地址,协议号等封装的报文,这个报头局域网中的所有主机都能够收到,收到的主机对比自己的mac地址和报文中的mac地址,如果不相等就直接丢弃,相等就接收向上进行交互,最后再进行应答。

总结:在局域网中的所有主机其实都能够收到对应的mac地址,只不过大部分主机在自己的数据链路层通过对比数据帧中的目标mac地址和自己的mac地址是否相等,来决策要不要再进行后续的处理

在局域网中,任何时刻,只能有一个主机发送消息,如果多个消息被同时发送,会导致局域网中的数据发生碰撞,那么就变成了无效数据,一个局域网,一个碰撞域。但是主机有主机的碰撞检测和碰撞避免算法来进行缓解碰撞。

如果我不断向局域网中发送垃圾数据,不执行碰撞检测和碰撞避免,就会导致局域网中的其他主机不能够正常的通信

在系统的视角来看,一个局域网就是一个临界资源,碰撞检测+碰撞避免,任何时刻只有一台主机能够向临界资源中写入数据(临界区)

对于局域网中的数据碰撞,可以加入交换机,来减小碰撞的概率

交换机识别到局部的碰撞之后,对碰撞的数据不做转发,加入交换机将局域网分为两部分,交换机的左边的两台主机进行通信,此时交换机不对正常的数据做转发,这样右边的碰撞概念也就降低了。交换机的作用就是划分了碰撞域,降低了碰撞率。

二、MTU

1.什么是MTU

MTU相当于发快递时对包裹尺寸的限制. 这个限制是不同的数据链路对应的物理层, 产生的限制.

以太网帧中的数据长度规定最小46字节,最大1500字节,ARP数据包的长度不够46字节,要在后面补填充位;

最大值1500称为以太网的最大传输单元(MTU),不同的网络类型有不同的MTU;

如果一个数据包从以太网路由到拨号链路上,数据包长度大于拨号链路的MTU了,则需要对数据包进行分片(fragmentation);

不同的数据链路层标准的MTU是不同的;

2.MTU对IP协议的影响

由于数据链路层MTU的限制, 对于较大的IP数据包要进行分包.

将较大的IP包分成多个小包, 并给每个小包打上标签;

每个小包IP协议头的 16位标识(id) 都是相同的;

每个小包的IP协议头的3位标志字段中, 第2位置为0, 表示允许分片, 第3位来表示结束标记(当前是否是最后一个小包, 是的话置为1, 否则置为0);

到达对端时再将这些小包, 会按顺序重组, 拼装到一起返回给传输层;

一旦这些小包中任意一个小包丢失, 接收端的重组就会失败. 但是IP层不会负责重新传输数据

在这里插入图片描述

在这里插入图片描述

3.MTU对UDP影响

一旦UDP携带的数据超过1472(1500 - 20(IP首部) - 8(UDP首部)), 那么就会在网络层分成多个IP数据报.

这多个IP数据报有任意一个丢失, 都会引起接收端网络层重组失败. 那么这就意味着, 如果UDP数据报在网络层被分片, 整个数据被丢失的概率就大大增加了.

4.MTU对于TCP协议的影响

TCP的一个数据报也不能无限大, 还是受制于MTU. TCP的单个数据报的最大消息长度, 称为MSS(Max Segment Size);

TCP在建立连接的过程中, 通信双方会进行MSS协商.

最理想的情况下, MSS的值正好是在IP不会被分片处理的最大长度(这个长度仍然是受制于数据链路层的MTU).

双方在发送SYN的时候会在TCP头部写入自己能支持的MSS值.

然后双方得知对方的MSS值之后, 选择较小的作为最终MSS.

MSS的值就是在TCP首部的40字节变长选项中(kind=2);

MSS和MTU的关系

在这里插入图片描述

查看硬件地址和MTU

使用ifconfig命令, 即可查看ip地址, mac地址, 和MTU;

ifconfig

在这里插入图片描述

三、ARP协议

ARP不是一个单纯的数据链路层的协议, 而是一个介于数据链路层和网络层之间的协议

1.ARP协议的作用

ARP协议建立了主机 IP地址 和 MAC地址 的映射关系.

在网络通讯时,源主机的应用程序知道目的主机的IP地址和端口号,却不知道目的主机的硬件地址;

数据包首先是被网卡接收到再去处理上层协议的,如果接收到的数据包的硬件地址与本机不符,则直接丢弃;

因此在通讯前必须获得目的主机的硬件地址;

2.ARP数据报的格式

在这里插入图片描述

注意到源MAC地址、目的MAC地址在以太网首部和ARP请求中各出现一次,对于链路层为以太网的情况

是多余的,但如果链路层是其它类型的网络则有可能是必要的。

硬件类型指链路层网络类型,1为以太网;

协议类型指要转换的地址类型,0x0800为IP地址;

硬件地址长度对于以太网地址为6字节;

协议地址长度对于和IP地址为4字节;

op字段为1表示ARP请求,op字段为2表示ARP应答

3.ARP协议的工作流程

主机将数据交付给吓一跳(下一跳的主机还是路由器等其他节点),前提一定是该数据帧被路由过,因为网络层在链路层的上层

通信时报文需要被封装称为mac帧,发送给目标主机,但是我们必须要知道目标主机的mac地址,那么就需要一个过程,让路由器设备认识目标主机,获取目标主机的mac地址。

路由器在整个局域网广播一个mac数据帧–封装ARP请求,报文的内容如下:

以太网目的地址:ffffff 表示向局域网中的所有主机发送,即广播
以太网源地址:自己的mac地址
帧类型:0806 表示IP协议
硬件类型:1
协议类型:0x0800
硬件地址长度:6
协议地址长度:4
op:1
发送端以太网地址:自己的mac地址
发送端IP地址:自己的IP地址
目的以太网地址:ffffff 
目的IP地址:需要知道MAC地址的主机的IP地址

局域网中的所有主机先查看op,知道是ARP请求还是ARP应答,然后再查看目的IP地址,与自己的IP地址进行比对,不相等就丢弃,相等就进行ARP应答,将自己的MAC地址封装在mac帧中,发送到询问的主机中。这样得到了目标主机的MAC地址

ARP协议:根据IP地址,获取目标主机的MAC地址,在获取对方的MAC地址之后,再发送MAC帧

所以ARP过程分为如下两步:

1.ARP请求阶段,在局域网中做广播

2.ARP响应,目标主机1v1发送给请求方主机

ARP的结果是会被存储起来的。ARP收到的结果会以最新的为主

在这里插入图片描述

源主机发出ARP请求,询问“IP地址是192.168.0.1的主机的硬件地址是多少”, 并将这个请求广播到本地网段(以太网帧首部的硬件地址填FF:FF:FF:FF:FF:FF表示广播);

目的主机接收到广播的ARP请求,发现其中的IP地址与本机相符,则发送一个ARP应答数据包给源主机,将自己的硬件地址填写在应答包中;

每台主机都维护一个ARP缓存表,可以用arp -a命令查看。缓存表中的表项有过期时间(一般为20分钟),如果20分钟内没有再次使用某个表项,则该表项失效,下次还要发ARP请求来获得目的主机的硬件地址

arp -a

在这里插入图片描述

ARP,IP,MAC的关系如下:

在这里插入图片描述

ARP欺骗

假如有主机1,2,3,IP地址和MAC地址分别为IP1,MAC1,IP2,MAC2,IP3,MAC3。

主机2给主机1发送ARP应答:我是IP3我的MAC地址为MAC2

主机2给主机3发送ARP请求:我是IP1,我的MAC地址为MAC2

此时主机1和主机3的ARP缓存表就会更新为最新的数据,那么此时主机1和主机3进行通信的数据都是发送到主机2,主机2可以对两台数据的数据进行转发,此时主机2就成为了中间人,就可以得到了主机1和主机3的通信信息。

当我们使用对称加密和非对称加密以及CA证书之后,主机2即使得到了内容也无法进行破解,如果对数据进行了更改,那么主机1和主机3就会知道。

RARP

有时候我们可能只知道对方的MAC地址,不知道IP地址,此时我们就可以使用RARP协议,和ARP一样的做法,就可以通过MAC地址,获取对方的IP地址。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/404350.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

命令执行 [WUSTCTF2020]朴实无华1

做题: 打开题目 我们用dirsearch扫描一下看看 扫描到有robots.txt,访问一下看看 提示我们 /fAke_f1agggg.php 那就访问一下,不是真的flag bp抓包一下 得到提示, /fl4g.php,访问一下看看 按alt,点击修复文…

使用 C++23 协程实现第一个 co_await 同步风格调用接口--Qt计算文件哈希值

C加入了协程 coroutine的特性,一直没有动手实现过。看了网上很多文章,已经了解了协程作为“可被中断和恢复的函数”的一系列特点。在学习过程中,我发现大多数网上的例子,要不就是在main()函数的控制台程序里演示yeild,await, resu…

Nginx网络服务二-----(虚拟机和location)

一、HTTP设置 1.设置虚拟主机 1.1Nginx 基于域名---虚拟主机 include /apps/nginx/conf.d/*.conf; 1.2Nginx 基于端口---虚拟主机 在做了域名的基础上,按照以下步骤继续 1.3Nginx 基于IP---虚拟主机 2.server下的root root路径格式 指定文件的路径 url …

1.1_1 计算机网络的概念、功能、组成和分类

文章目录 1.1_1 计算机网络的概念、功能、组成和分类(一)计算机网络的概念(二)计算机网络的功能(三)计算机网络的组成1.组成部分2.工作方式3.功能组成 (四)计算机网络的分类 总结 1.…

线性代数:向量空间

目录 向量空间 Ax 0 的解空间S Ax b 的全体解向量所构成集合不是向量空间 基、维数、子空间 自然基与坐标 例1 例2 向量空间 Ax 0 的解空间S Ax b 的全体解向量所构成集合不是向量空间 基、维数、子空间 自然基与坐标 例1 例2

使用redisMQ-spring-boot-starter实现消息队列和延时队列

简介 redisMQ-spring-boot-starter是一个轻量级的、基于Redis实现的消息队列中间件,它有如下优点: 开箱即用,你几乎不用添加额外的配置支持消息队列、延时队列,并提供精细化配置参数提供消息确认机制支持虚拟空间,不…

非洲数字经济持续崛起 本地化策略让传音提前入局

非洲市场,被誉为全球最后的“边疆级”市场,吸引着全球目光。近日,非洲开发银行最新报告指出,未来两年非洲的经济增长将优于世界其他地区,2023 年和 2024 年实际国内生产总值 (GDP) 平均约为 4%。广阔的非洲大陆焕发着勃…

PLC设置网口通讯的原因

PLC设置网口通讯功能,是现场总线向工业以太网的迈进,更是为了在网口之上构建更为庞大、开放的大一统的生态系统。 有了以太网,特别是TCP/IP协议后,全员工控人的日常工作更为便利了。 主要体现在以下4点: 1.再也不需要…

TiDB 社区智慧合集丨TiDB 相关 SQL 脚本大全

非常感谢各位 TiDBer 在之前 【TiDBer 唠嗑茶话会 48】非正式 TiDB 相关 SQL 脚本征集大赛!( https://asktug.com/t/topic/996635 )里提供的各种常用脚本。 在这篇文章中,我们整理了社区同学提供的一系列 TiDB 相关 SQL 脚本,希望能为大家在…

基于springboot+vue的车辆管理系统(前后端分离)

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 ​主要内容:毕业设计(Javaweb项目|小程序|Pyt…

【云动世纪:Apache Doris 技术之光】

本文节选自《基础软件之路:企业级实践及开源之路》一书,该书集结了中国几乎所有主流基础软件企业的实践案例,由 28 位知名专家共同编写,系统剖析了基础软件发展趋势、四大基础软件(数据库、操作系统、编程语言与中间件…

短视频新媒体的福音:视频抽插帧AI效率是人工的100倍以上

进入全民短视频时代,人像视频的拍摄也正在迈向专业化。随着固化审美的瓦解,十级磨皮的网红滤镜被打破,多元化的高级质感成为新的风向标,“美”到每一帧是人们对动态视频提出的更高要求。 目前,大部分手机均可记录主流的…

【Vuforia+Unity】AR05-实物3D模型识别功能实现(ModelTarget )

不管是什么类型的识别Vuforia的步骤基本都是: 把被识别的物体转成图、立体图、柱形图,3D模型、环境模型,然后模型生成Vuforia数据库-导入Unity-参考模型位置开始摆放数字内容,然后参考模型自动隐藏-发布APP-识别生活中实物-数字内…

体验LobeChat搭建私人聊天应用

LobeChat是什么 LobeChat 是开源的高性能聊天机器人框架,支持语音合成、多模态、可扩展的(Function Call)插件系统。支持一键免费部署私人 ChatGPT/LLM 网页应用程序。 地址:https://github.com/lobehub/lobe-chat 为什么要用Lobe…

【Python笔记-设计模式】工厂模式

一、说明 (一) 解决问题 提供了一种方式,在不指定具体类将要创建的情况下,将类的实例化操作延迟到子类中完成。可以实现客户端代码与具体类实现之间的解耦,使得系统更加灵活、可扩展和可维护。 (二) 使用场景 希望复用现有对象来节省系统…

C# cass10 宗地初始化-根据 “预编号” “权利人”图层对应信息 批量添加到宗地图层

运行环境Visual Studio 2022 c# cad2016 cass10 根据 “预编号” “权利人”图层对应信息 批量添加到宗地图层 一、主要步骤 zdimport 方法:这个方法用于导入宗地信息。首先通过调用 AutoCAD API 获取当前活动文档、数据库和编辑器对象。然后根据 CreatePalette.Se…

Web3 基金会推出去中心化之声计划:投入高额 DOT 和 KSM ,助力去中心化治理

作者:Web3 Foundation Team 编译:OneBlock 原文:https://medium.com/web3foundation/decentralized-voices-program-93623c27ae43 Web3 基金会为 Polkadot 和 Kusama 创建了去中心化之声计划(Decentralized Voices Program&…

【深度学习笔记】3_1 线性回归

注:本文为《动手学深度学习》开源内容,仅为个人学习记录,无抄袭搬运意图 3.1 线性回归 线性回归输出是一个连续值,因此适用于回归问题。回归问题在实际中很常见,如预测房屋价格、气温、销售额等连续值的问题。与回归问…

3.测试教程 - 基础篇

文章目录 软件测试的生命周期软件测试&软件开发生命周期如何描述一个bug如何定义bug的级别bug的生命周期如何开始第一次测试测试的执行和BUG管理产生争执怎么办(处理人际关系) 大家好,我是晓星航。今天为大家带来的是 测试基础 相关的讲解…

C++最佳实践之编译篇

C最佳实践之工程编译 在大型c/c工程开发中,往往会涉及多级CMakeLists.txt的调用,并且调用方式错综复杂,主要有以下两种方式: 1. 子目录中的CMakeList.txt独立生成目标,不作为主目标生成过程的依赖关系(比…