【网络协议栈】数据链路层(内附手画分析图 简单易懂)以太网、MAC地址、局域网、交换机、MTU、ARP协议

请添加图片描述
每日激励:【无限进步】“梦想可以大,但第一步总是小”

绪论​:
本章将开始到达TCP/IP协议中的最后一层数据链路层,本章将会写到我们日常中常见的局域网以及认识数据链路层中非常重要的协议ARP协议,后续还将进行更新网络,敬请期待!
————————
早关注不迷路,话不多说安全带系好,发车啦(建议电脑观看)。


数据链路层

用于两个设备(同一种数据链路节点)之间进行传递,对于数据链路层来说它是用来具体实现传输层的下一跳这个功能,当传输层选择了下一跳的路由或主机后,由数据链路层来完成下一跳功能

认识以太网

  • “以太网” 不是一种具体的网络,而是一种技术标准;既包含了数据链路层的内容,也包含了一些物理层的内容。例如:规定了网络拓扑结构,访问控制方式,传输速率等;
  • 例如以太网中的网线必须使用双绞线;传输速率有10M、100M、1000M等
  • 以太网是当前应用最广泛的局域网技术,和以太网并列的还有令牌环网,无线LAN等;
  • 总结来说:以太网就是一种局域网技术,它包含了数据链路层和一些物理层内容。规定了在以太网内部的运行规则,在这些规则的基础上才能进行以太网中的局域网通信。

MAC地址

每台主机都有mac地址,并且它是全球唯一的(局域网中通信的时候用的就是MAC地址)
在这里插入图片描述
在这里插入图片描述
上图具体如下:

  1. 源地址和目的地址是指网卡的硬件地址(也叫MAC地址),长度是48位,是在网卡出厂时固化的;
  2. 帧协议类型字段有三种值,分别对应IP、ARP、RARP;
  3. 帧末尾是CRC校验码
  • 在一个局域网中一个报文数据有两套地址的,一套是ip地址、一套是Mac地址,ip地址始终保持不变,而mac地址是在局域网中使用(它的使用方法和ip地址一样),所以当从一个局域网跳到另一个局域网时(路由转发)就会发生改变(因为mac地址存的是源Mac地址和目的MAC地址,随着跳转Mac地址也会随之)。

  • 当一台主机发送报文时,同一个局域网内的所有主机都会收到数据,其中所有主机都会判断是否是发给自己的若是则接受后再向上交付到网络层根据目的IP和查路由表确定下一跳的,并重新封装然后继续在链路层传输(目的ip不变,mac地址发送改变),反之直接丢弃(将网卡设置混杂模式则不会丢弃所有都接收)。

  • 上述过程具体如下图局域网:
    在这里插入图片描述

附:常见的ether表示的就是Mac地址

局域网

局域网的特性:

  1. 局域网中,任何时刻只允许一台主机在局域网发送数据
  2. 同时发送的话,会发生局域网数据碰撞问题
  3. 也就有:碰撞检测 碰撞避免问题
  4. 碰撞避免问题:当主机间发生了数据碰撞的话就会让主机先休眠一段时间后再发送

所以局域网其实就像一个多台主机的临界区(划分出一个个区域)

数据链路层中常见的的设备:网桥、交换机

交换机

交换机作用:
将一个子网在划分成更小的子区域,从而缓解网络的压力(信号量划分资源让多个线程使用)
应用于一些较大的子网中
同一个局域网资源,主机越多碰撞概率越大,通过不断的数据传输,自我学习构建映射关系,确定主机的位置,进行划分碰撞域

例:

  1. A向E发送时,A就会被映射为在左边,E就会被确定为右边
  2. 当A再向C发送报文后,C又会被确定在右边,通过不断的学习就能划分碰撞域
    从而:
  3. 当C要向E发送时,通过交换机就能知道他们都在右边建立映射这样就不向左边发送报文了
  4. 起到类似隔离的效果,一定的防止影响到局部的主机通信

如下图:
在这里插入图片描述

这样当把一个局域网通过交换机再次的划分成多个“小局域网”,这样就能允许多个主机在同一个 “大局域网” 同时通信了。

认识MTU

以太网帧中的数据长度规定数据大小是46~1500,这个就表示这该数据最大的大小为1500byte,其中这1500是由MTU设置而成,MTU限制了数据的大小。
因为:

  • 若数据太大则在局域网中通信的时候发生碰撞的概率就会变的更大
  • 查看硬件地址和MTU:使用shell指令:ifconfig命令。即可查看ip地址,mac地址,和MTU;在这里插入图片描述

所以限制一定的大小这样就能:

  1. 减少碰撞的概率
  2. 碰撞后重发的成本消耗

所以:

  1. TCP的一个数据报也不能无限大, 还是受制于MTU。TCP的单个数据报最大消息长度,称为MSS(Max Segment Size);
  2. 最理想的情况下,MSS的值正好是在IP不会被分片处理的最大长度(这个长度仍然是受制于数据链路层的MTU)

ARP协议

虽然我们在这里介绍ARP协议,但是需要强调,ARP不是一个单纯的数据链路层的协议,而是一个介于数据链路层和网络层之间的协议

ARP协议的作用:
地址解析协议(属于数据链路层中的管理类协议,网络协议栈在局部上(某一层上)也是分层的)根据对方的目的IP地址,得到目标主机的Mac地址。因为其实我们在数据中只有对方目的ip,最终也只能找到对方的所在的子网,而没有mac地址,就无法再局域网中通信

ARP的工作步骤:

  1. 在局域网中发送广播信息(目标mac地址全F)信息内容:我是macA,你的ip是否为目标ip,若是请告诉我你的mac地址。
  2. 向macA发送:我是目标地址,我的mac地址是macE。
  3. 这样主机A就拿到了他的mac地址,然后再把数据封装上目标ip的mac地址(mac帧报头),就能发送找到目标ip的mac地址。

在这里插入图片描述

细节:

  1. 主机得到arp结果,会将结果缓存起来,这样能减少arp请求次数(每台主机都维护一个ARP缓存表,可以用arp -a命令查看。缓存表中的表项有过期时间(一般为20分钟),如果20分钟内没有再次使用某个表项,则该表项失效,下次还要发ARP请求来获得目的主机的硬件地址)
  2. 任何一台主机都可能受到arp请求(别人问我),又收到arp应答(我问别人)

ARP协议的字段结构:
在这里插入图片描述

  1. 硬件类型指链路层网络类型,1为以太网;
  2. 协议类型指要转换的地址类型,0x0800为IP地址;
  3. 硬件地址长度:以太网地址为6字节(mac地址,一般固定写);
  4. 协议地址长度:IP地址为4字节(ip转mac,一般固定写);
  5. op字段为1表示ARP请求,op字段为2表示ARP应答。
  6. 发送端以太网地址:也就是发送端的mac地址
  7. 发送端IP地址:…
  8. 目的以太网地址:发送端(ARP请求)不知道时:填全F(FF FF FF FF)表示广播、ARP应答时就会填上(表示要发送到的主机)。
  9. 目的IP地址

此时前面的帧类型就要填充为表示:ARP请求/应答 和 类型 0806
在这里插入图片描述

例:若要从ipA所在的局域网中找目的ipH,那么填充的报头应该是:
在这里插入图片描述

ARP请求时:
当发生ARP请求报文时,填写目的ip为ipH的主机,它接受到这个请求报文后

  1. 先看op(查看是请求还是应答),
  2. 若是请求就看其报文内的目的ip和自身ip是否相等(在ARP层判断)
  3. 相等就会构建ARP应答返回给请求的主机
  4. 反之若不是则丢弃。
    在这里插入图片描述

ARP应答时:

  1. 当收到ARP应答时判断以太网首部中的以太网的目的地址(在数据链路层的最底层mac帧中判断的)
  2. 若是发给自己的,同样是先看op,发现为2(表示为应答),就提取发送方的mac地址
  3. 这样就成功的获取到了目的ip的Mac地址
  4. 也就完成了ARP协议的全过程

其中请求和应答是在不同层中判断的,因为:检查应答中的源IP地址和源MAC地址是否与请求中的目标IP地址和期望的MAC地址匹配,是在网络层中的。

ARP欺骗(如何成为中间人)

前提知识:
arp缓存时,如果收到了很多同类型的arp应答,它会将最新的arp记录下来
在这里插入图片描述
通过自己的主机向所要攻击的主机和该主机发送的arp请求对应的主机,发送大量的自己虚构的arp应答假装自己为该主机之前发送的arp请求的应答从而让他的arp缓存记录为自己主机的mac地址这样后面当攻击主机要发送数据给路由(或主机)时,实际上是发给我们这台主机,我们就能进行篡改数据,然后在我们在发出去。


本章完。预知后事如何,暂听下回分解。

如果有任何问题欢迎讨论哈!

如果觉得这篇文章对你有所帮助的话点点赞吧!

持续更新大量计算机网络细致内容,早关注不迷路。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二叉树的深搜(不定期更新。。。。。)

二叉树的深搜 验证二叉搜索树 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下: 节点的左 子树 只包含 小于 当前节点的数。 节点的右子树只包含 大于 当前节点的数。 所有左子树和右子树自身必须也是二叉…

51c嵌入式~单片机合集3

我自己的原文哦~ https://blog.51cto.com/whaosoft/12581900 一、STM32代码远程升级之IAP编程 IAP是什么 有时项目上需要远程升级单片机程序,此时需要接触到IAP编程。 IAP即为In Application Programming,解释为在应用中编程,用户自己的程…

使用setsockopt函数SO_BINDTODEVICE异常,Protocol not available

前言 最近在使用OLT的DHCP Server的时候发现一些异常现象,就是ONU发的一个vlan的discover包其他不同vlan的DHCP地址池也会收到,导致其他服务器也发了offer包,ONU同时会有多个ip地址。一开始是没有使用SO_BINDTODEVICE,后面查到使…

02 conda常用指令

目录 命令快速查找命令详细解释列出当前conda中存在的解释器环境使用指定的解释器环境创建虚拟环境激活自己创建的虚拟环境虚拟环境删除切换回主环境找到你计算机中安装的miniconda3的跟目录找到虚拟环境的目录选择需要删除的虚拟环境文件夹确认环境是否删除 补充删除虚拟环境指…

BEVFormer详细复现方案

✨✨ 欢迎大家来访Srlua的博文(づ ̄3 ̄)づ╭❤~✨✨ 🌟🌟 欢迎各位亲爱的读者,感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢,在这里我会分享我的知识和经验。&am…

应用案例 | 船舶海洋: 水下无人航行器数字样机功能模型构建

水下无人航行器数字样机功能模型构建 一、项目背景 为响应水下装备系统研制数字化转型及装备系统数字样机建设的需要,以某型号水下无人航行器(Underwater Unmanned Vehicle,UUV)为例,构建UUV数字样机1.0功能模型。针对…

【NIPS2024】Unique3D:从单张图像高效生成高质量的3D网格

背景(现有方法的不足): 基于Score Distillation Sampling (SDS)的方法:从大型二维扩散模型中提取3D知识,生成多样化的3D结果,但存在每个案例长时间优化问题/不一致问题。 目前通过微…

手机LCD分区刷新技术介绍

分区刷新也称为分区变频,LCD分区刷新功能的目的是将屏幕分为上下半区,分区显示不同帧率,上方区块High Frame Rate,下方区块Low Frame Rate。使用者可以动态自定义上方高刷显示区的结尾位置。 当前的智能手机屏幕上,显示…

NLP算法具备技能

摘要:好久不看理论,最近把自己学过以及用到过的东西都列了出来,主要是这个大纲体系,详细的内容部分是使用LLM来辅助编写的。 一、大模型 1.1 常用大模型 1.1.1 Qwen ‌Qwen大模型‌是由阿里巴巴开发的系列大语言模型&#xff…

学习日志022 -- python事件机制

作业: 1】思维导图 2】完成闹钟 main.py import sysfrom PySide6.QtCore import QTimerEvent, QTime,Qt from PySide6.QtGui import QMovie,QMouseEvent from PySide6.QtWidgets import QApplication, QWidget from Form import Ui_Formclass MyWidget(Ui_Form,Q…

JAVAWeb中的Servlet学习

一 Servlet简介 1.1动态资源和静态资源 静态资源 无需在程序运行时通过代码运行生成的资源,在程序运行之前就写好的资源.例如:html css js img ,音频文件和视频文件 动态资源 需要在程序运行时通过代码运行生成的资源,在程序运行之前无法确定的数据,运行时动态生成,例如Servle…

重生在我在21世纪学C++—赋值操作符、类型转换、单目操作符

一、赋值操作符 在变量创建的时候给一个初始值叫初始化。在变量创建好后,再给⼀个值,这叫赋值。 int a 100 ; //这叫初始化 a 200 ; //这叫赋值, 就是赋值操作符 赋值操作符 是⼀个随时可以给变量(不能是常…

03、Node.js安装及环境配置

1.下载node.js 下载地址:Node.js 2.安装 2.1 自定义安装路径(可以选择默认) 下图根据本身的需要进行,我选择了默认Node.js runtime,然后Next: Node.js runtime :表示运行环境 npm package mana…

【Java】反射简介

框架的核心和架构师的核心 反射和代理是重中之重 反射 反射的作用 在运行的时候由代码获取类的信息 三种获取类信息的方式: 对象.getClass()Class.forName("类的路径")类.class Class :一个用来存储类信息的类 获取类信息是获取的整体的…

Qt入门8——Qt文件

1. Qt文件概述 文件操作是应用程序必不可少的部分。Qt作为⼀个通用开发库,提供了跨平台的文件操作能力。Qt 提供了很多关于文件的类,通过这些类能够对文件系统进行操作,如文件读写、文件信息获取、文件复制或重命名等。 2. 输入输出设备类 在…

常量变量和一些运算符

3.4 变量 常量:!final关键字 final修饰基本类型不可以第二次赋值final修饰的引用类型不可以第二次改变指向final修饰的类不可以被继承final修饰的方法不可以被重写final防止指令重排序,遏制流水线性能优化,保障多线程并发场景下…

内存管理面试常问

为什么要有虚拟内存? 虚拟内存 如果你是电⼦相关专业的,肯定在⼤学⾥捣⿎过单⽚机。 单⽚机是没有操作系统的,所以每次写完代码,都需要借助⼯具把程序烧录进去,这样程序才能跑起来。 另外, 单⽚机的 CPU …

MongoDB分片集群搭建及扩容

分片集群搭建及扩容 整体架构 环境准备 3台Linux虚拟机,准备MongoDB环境,配置环境变量。一定要版本一致(重点),当前使用 version4.4.9 配置域名解析 在3台虚拟机上执行以下命令,注意替换实际 IP 地址 e…

【HarmonyOS】层级轮播卡片效果

【HarmonyOS】层级轮播卡片效果 一、功能效果: 1.上下堆叠由大到小的卡片层叠效果。 2.上层卡片可手势左右滑动,自动左滑动。 3.三层卡片随滑动,内容进行依次切换。 二、开发思路 【完整代码见章节三】 1.最上层使用swiper进行轮播效果…

Python_Flask02

所有人都不许学Java了,都来学Python! 如果不来学的话请网爆我的老师 连接前的准备 安装pymysql 和 flask_sqlalchemy,安装第三下面两个所需要的包才能连接上数据库 pip install pymysql pip install flask_sqlalchemy pymysql是一个Pyth…