3.11.2、虚拟局域网 VLAN 实现机制

news2024/11/17 17:36:06

虚拟局域网 VLAN 技术是在交换机上实现的,需要交换机能够实现以下两大功能

  • 能够处理带有 VLAN 标记的帧:IEEE 802.1Q
  • 交换机的各端口支持不同的端口类型(帧的处理方式有所不同)

1、IEEE 802.1Q 帧

IEEE 802.1Q 帧(也称 Dot One Q 帧)对以太网的 MAC 帧格式进行了扩展,插入了 4 4 4 字节的 VLAN 标记。

  • 以太网版本 2 2 2MAC 帧格式

image-20221224181742155

  • 插入 VLAN 标记的 802.1Q 帧格式

image-20221224181825814

VLAN 标记的最后 12 12 12 个比特称为 VLAN 标识符 VID,它唯一的标志了以太网属于哪一个 VLAN

  • VID 的取值范围为 0 0 0 ~ 4095 4095 4095 0 0 0 ~ 2 12 − 1 2^{12}-1 2121
  • 0 0 0 4095 4095 4095 都不用来表示 VLAN ,因此用于表示 VLANVID 的有效取值范围是 1 1 1 4094 4094 4094

注意:

  • 802.1Q 帧是由交换机来处理的,而不是用户主机来处理的。

当交换机收到普通的以太网帧时,会将其插入 4 4 4 字节的 VLAN 标记转变为 802.1Q 帧,简称 “ 打标签 \color{red}打标签 打标签

当交换机转发 802.1Q 帧时,可能会删除其 4 4 4 字节 VLAN 标记转变为普通以太网帧,简称 “ 去标签 \color{red}去标签 去标签

2、交换机的端口类型

交换机的端口类型有以下三种:

  • Access

  • Trunk

  • Hybrid(思科交换机没有该端口)


交换机各端口的缺省 VLAN ID

  • 在思科交换机上称为 Native VLAN,即本征 VLAN

    • 例如:思科交换机在用户未配置 VLAN 时,所有端口都默认属属于 VLAN1

      ​ 即:所有端口的本征 VLAN 都是 VLAN1

  • 在华为交换机上称为 Port VLAN ID,即端口 VLAN ID,简记为 PVID

说明:以下均采用华为交换机

注意:

  • 交换机的每个端口有且只有一个 PVID

2.1、Access 端口

Access 端口一般用于连接用户计算机

Access 端口只能属于一个VLAN

Access 端口的 PVID 值与端口所属 VLANID 相同(默认为 1 1 1


例如:主机 ABCD 分别连接在交换机的一个端口上

交换机首次上电时,默认配置个端口属于 VLAN1

  • 也就是各端口的 PVID 值等于 1 1 1

默认配置各端口的类型为 AccessA 标识)

image-20221224183310907


2.1.1、接受处理方法

Access 端口接收处理方法:

  • 一般只接受 “未打标签” 的普通以太网 MAC 帧。
  • 根据接收帧的端口的 PVID 给帧 “ 打标签 \color{red}打标签 打标签” ,即插入 4 4 4 字节 VLAN 标记字段,字段中的 VID 取值与端口的 PVID 取值相等。

假设主机 A 发送了一个广播帧

该帧从交换机的端口 1 1 1 进入交换机。

由于端口 1 1 1 的类型是 Access,它会对接收到的 “未打标签” 的普通以太网 MAC 帧 “打标签” 。

  • 插入 4 4 4 字节的 VLAN 标记字段

由于端口 1 1 1PVID 值也等于 1 1 1,因此所插入的 4 4 4 字节 VLAN 标记字段中的 VID 的值也等于 1 1 1

image-20221224183742060


2.1.2、发送处理方法

Access 端口发送处理方法:

  • 若帧中的 VID 与端口的 PVID 相等,则 “ 去标签 \color{red}去标签 去标签” 并转发该帧
  • 否则不转发。

广播帧中的 VID 的取值与端口 2 、 3 、 4 2、3、4 234PVD 取值都等于 1 1 1

  • 因此,交换机会从这三个端口对帧进行 “去标签” 转发

image-20221224184110276


若将主机 AB 划归的 VLAN2,将主机 CD 划归到 VLAN3

这样,VLAN2 的广播帧不会传送到 VLAN3。反之亦然

image-20221224184220002

为了实现这种应用,可以在交换机上创建 VLAN2VLAN3,然后将交换机的端口 1 1 1 2 2 2 划归到 VLAN2

  • 因此,端口 1 1 1 2 2 2PVID 值等于 2 2 2

将交换机的端口 3 3 3 4 4 4 划归到 VLAN3

  • 因此,端口 3 3 3 4 4 4PVID 值等于 3 3 3

image-20221224184413579

假设主机 A 发送了一个广播帧

该帧从交换机的端口 1 1 1 进入交换机。

由于端口 1 1 1 的类型是 Access,它会对接收到的 “未打标签” 的普通以太网 MAC 帧 “打标签” 。

  • 插入 4 4 4 字节的 VLAN 标记字段

由于端口 1 1 1PVID 值等于 2 2 2,因此所插入的 4 4 4 字节 VLAN 标记字段中的 VID 的值也等于 2 2 2

image-20221224184526323

广播帧中的 VID 值与端口 2 2 2PVID 值都等于 2 2 2

  • 因此,交换机会从端口 2 2 2 对帧进行 “去标签” 转发。

image-20221224184642946

假设主机 C 发送了一个广播帧

该帧从交换机的端口 3 3 3 进入交换机。

由于端口 3 3 3 的类型是 Access,它会对接收到的 “未打标签” 的普通以太网 MAC 帧 “打标签” 。

  • 插入 4 4 4 字节的 VLAN 标记字段

由于端口 3 3 3PVID 值等于 3,因此所插入的 4 字节 VLAN 标记字段中的 VID 的值也等于 3 3 3

image-20221224184728475

广播帧中的 VID 值与端口 4 4 4PVID 值都等于 3 3 3

  • 因此,交换机会从端口 4 4 4 对帧进行 “去标签” 转发。

image-20221224184808103

2.2、Trunk 端口

Trunk 端口一般用于交换机之间或交换机与路由器之间的互连

Trunk 端口可以属于多个 VLAN

  • Trunk 端口可以接受和发送多个 VLAN 的帧

用户可以设置 Trunk 端口的 PVID 值。默认情况下, Trunk 端口的 PVID 值为 1 1 1


两台交换机互连而成了一个交换式以太网

image-20221224185752567

将主机 ABEF 划归到 VLAN1,将主机 CDGH 划归到 VLAN2

由于交换机首次上电时默认配置各端口属于 VLAN1

  • 其相应的 PVID 值等于 1 1 1,并且端口的类型为 Access

因此,我们需要对交换机进行相应的配置才能满足应用需求

  • 分别在两个交换机上创建 VLAN2,并将它们的端口 3 和 4 都划归到 VLAN2,其相应的 PVID 值等于 2 2 2
  • 而两个交换机的端口 1 1 1 2 2 2 保持默认配置即可,也就是属于 VLAN1,其相应的 PVID 值等于 1 1 1

image-20221224190310285

注意:需要将交换机互联的端口 5 5 5 的类型更改为 Trank 类型,其 PVID 值默认 1 1 1 即可


2.2.1、发送处理方法

Trank 端口发送处理方法:

  • VID 等于 PVID 的帧,“ 去标签 \color{red}去标签 去标签” 再转发
  • VID 不等于 PVID 的帧, 直接转发 \color{red}直接转发 直接转发

假设主机 A 发送了一个广播帧

该帧从交换机 1 1 1 的端口 1 1 1 进入交换机。

由于端口 1 1 1 的类型是 Access,它会对接收到的 “未打标签” 的普通以太网 MAC 帧 “打标签” 。

  • 插入 4 4 4 字节的 VLAN 标记字段

由于端口 1 1 1PVID 值也等于 1 1 1,因此所插入的 4 4 4 字节 VLAN 标记字段中的 VID 的值也等于 1 1 1

该广播帧中的 VID 的取值与端口 2 2 2PVID 值都等于 1 1 1,端口 2 2 2 的类型是 Access

  • 因此,交换机 1 1 1 会从端口 2 2 2 对帧进行 “去标签” 转发。

image-20221224190834066

该广播帧中的 VID 的取值与端口 5 5 5PVID 值都等于 1 1 1,端口 5 5 5 的类型是 Trank

  • 因此,交换机 1 1 1 会从端口 5 5 5 对帧进行 “去标签” 转发。

image-20221224191017399

很显然,该广播帧会从交换机 2 2 2 的端口 5 5 5 进入交换机 2 2 2


2.2.2、接受处理方法

Trunk 端口接收处理方法:

  • 接收 “未打标签” 的帧,根据接收帧的端口的 PVID 给帧 “ 打标签 \color{red}打标签 打标签

    即插入 4 4 4 字节 VLAN 标记字段,字段中的 VID 取值与端口的 PVID 取值相等。

  • 接受 “已打标签的帧”

对上述广播帧

交换机 2 2 2 会对接受到的 “未打标签” 的普通以太网 MAC 帧 “打标签” 。

  • 也就是插入 4 4 4 字节的 VLAN 标志字段

由于端口 5 5 5PVID 值等于 1 1 1

  • 因此,所插入的 4 4 4 字节 VLAN 标记字段中的 VID 值也等于 1 1 1

image-20221224191600938

该广播帧中的 VID 值与 端口 1 1 1 2 2 2PVID 值都等于 1 1 1,端口 1 1 1 2 2 2 的类型都是 Access

  • 因此,交换机 2 2 2 会从端口 1 1 1 2 2 2对帧进行 “去标签” 转发。

image-20221224191609838


假设主机 C 发送了一个广播帧

该帧从交换机 1 1 1 的端口 3 3 3 进入交换机。

由于端口 3 3 3 的类型是 Access,它会对接收到的 “未打标签” 的普通以太网 MAC 帧 “打标签” 。

  • 插入 4 4 4 字节的 VLAN 标记字段

由于端口 3 3 3PVID 值等于 2 2 2,因此所插入的 4 4 4 字节 VLAN 标记字段中的 VID 的值也等于 2 2 2

该广播帧的 VID 取值 与端口 4 4 4PVID 值都等于 2 2 2,端口 4 4 4 的类型是 Access

  • 因此,交换机 1 1 1 会从端口 4 4 4 对帧进行 “去标签” 转发。

image-20221224191952881

该广播帧的 VID 的值与端口 5 5 5PVID 值不相等,由于 Trunk 端口对 VID 不等于 PVID 的帧是 直接转发 \color{red}直接转发 直接转发的。

  • 因此,交换机 1 1 1 会从端口 5 5 5 对帧直接转发
  • 也就是不去掉标签而带着标签直接转发

很显然,该 802.1Q 广播帧会从交换机 2 2 2 的端口 5 5 5 进入交换机 2 2 2

Trank 端口接受已打标签的 802.1Q

该广播帧的 VID 的取值与端口 3 3 3 4 4 4PVID 值都等于 2 2 2,端口 3 3 3 4 4 4 的类型都是 Access 类型

  • 因此,交换机 2 2 2 会从端口 3 3 3 4 4 4 对帧进行 “去标签” 转发。

image-20221224192537749

2.3、小总结

在由多个交换机互连而成的交换式以太网中划分 VLAN 时。

  • 连接主机的交换机端口应设置为 Access 类型

  • 交换机之间互连的端口应设置为 Trank 类型

2.4、习题

image-20221224192754895

解析

image-20221224193101756

2.5、Hybrid 端口

Hybrid 端口既可用于交换机之间或交换机与路由器之间的互连(同 Trunk 端口),也可用于交换机与用户计算机之间的互连(同 Access 端口)

Hybrid 端口可以属于多个 VLAN (同 Trunk 端口)用户可以设置 Hybrid 端口的 PVID 值。

  • 默认情况下 Hybrid 端口的 PVID 值为 1 1 1 (同 Trunk 端口)

Hybrid 端口发送处理方法( 与 T r u n k 端口不同 \color{red}与 Trunk 端口不同 Trunk端口不同)查看帧的 VID 是否在端口的 “去标签” 列表中;

  • 若存在,则“去标签”后再转发;

  • 若不存在,则直接转发;


Hybrid 端口接收处理方法(同 Trunk 端口)

  • 接收 “未打标签” 的帧,根据接收帧的端口的 PVID 给帧“打标签”

    即插入 4 4 4 字节 VLAN 标记字段,字段中的 VID 取值与端口的 PVID 取值相等。

  • 接收 “已打标签的帧” ;


image-20221224193948767

主机 AC 发送数据帧

该帧从交换机的端口 1 1 1 进入交换机,由于端口 1 1 1 的类型是 Hybrid

  • 它会对接收到的 “未打标签”的 普通以太网 MAC 帧 “打标签”

由于端口 1 1 1PVID 值等于 10 10 10

  • 因此,所插入的 4 4 4 字节 VLAN 标记字段中的 VID 的值也等于 10 10 10

该帧将从端口 3 3 3 转发,由于帧中的 VID 的取值再端口 3 3 3 的去标签列表中

  • 因此,该帧会被 “去标签” 转发

这样主机 C 就可以收到主机 A 发送的数据帧

image-20221224194402229

同理,主机 CA 发送数据帧,主机 A 同样可以收到


主机 BC 发送数据帧

image-20221224194505597

同理,主机 CB 发送数据帧,主机 B 同样可以收到


主机 AB 发送数据帧

该帧从交换机的端口 1 1 1 进入交换机,给该帧打标签,其中 VID 取值为 10 10 10

该帧将从端口 2 2 2 转发

由于帧中的 VID 的取值不在端口 2 2 2 的去标签列表中。

  • 因此,该帧被直接转发

这样主机 B 就会收到一个带有 VLAN 标记的 802.1Q

  • 但是主机 B 可以识别普通以太网 MAC 帧,而不能识别 802.1Q 帧,只能丢弃该帧

image-20221224194839422

主机 BA 发送数据帧同理

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

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

相关文章

Java项目:SpringBoot美容院预约管理系统

作者主页:源码空间站2022 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 本系统分为管理员与普通用户两种角色; 管理员角色包含以下功能: 登录,首页,新增管理员,管理员信息列表,网站用户信息列表…

node.js+uni计算机毕设项目基于微信小程序校园心理咨询(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置: Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等…

RabbitMQ 第一天 基础 1 MQ的基本概念 1.1 MQ 概述 1.2 MQ的优势和 劣势 1.3 MQ的优势

RabbitMQ 【黑马程序员RabbitMQ全套教程,rabbitmq消息中间件到实战】 文章目录RabbitMQ第一天 基础1 MQ的基本概念1.1 MQ 概述1.1.1 MQ 概述1.1.2 小结1.2 MQ的优势和 劣势1.2.1 概述1.3 MQ的优势1.3.1 应用解耦1.3.2 异步提速1.3.3 削峰填谷1.3.4 小结第一天 基础…

【SpringMVC】SpringMVC模型数据+视图解析器

目录 一、模型数据-如何将数据存入request域 二、模型数据-如何将数据存入session域 三、ModelAttribute 四、视图解析器 相关文章 【SpringMVC】入门篇:带你了解SpringMVC的执行流程【SpringMVC】入门篇:带你了解SpringMVC的执行流程 【SpringMVC】使用…

springboot整合swagger

特别说明:本次项目整合基于idea进行的,如果使用Eclipse可能操作会略有不同,不过总的来说不影响。 springboot整合之如何选择版本及项目搭建 springboot整合之版本号统一管理 springboot整合mybatis-plusdurid数据库连接池 springboot整合…

node.js+uni计算机毕设项目儿童健康成长档案小程序(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置: Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等…

暂时性死区以及函数作用域

暂时性死区 暂时性死区也就是变量声明到声明完成的区块,这个区块是一个封闭的作用域,直到声明完成。 如果在变量声明之前使用该变量,那么该变量是不可用的,也就被称为暂时性死区。 var 没有暂时性死区,因为var存在变…

Python编程 递归函数

作者简介:一名在校计算机学生、每天分享Python的学习经验、和学习笔记。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 一.函数执行注意点 二.递归函数 1.递归的介绍 2.例子 前言 本章将会讲解…

新版H5微信网页JS-SDK自定义分享功能实现

1.先用 微信官方文档demo,下载下来去改就行, 概述 | 微信开放文档 2.(后端)填写上认证后的,公众号appid,appsecret。 3.(前端代码) 配置好需要的接口(调试打开debug&a…

自研框架(Webx)整合Zuul网关工作总结

写在前面,最近被分配了一个技术任务,简单描述为自研框架(类比Spring)整合一个微服务网关,并且能用就行。 有人可能会问,想用微服务网关,不是直接引入zuul或者gateway相关的依赖,然后…

【Pandas入门教程】如何合并多个表中的数据

如何合并多个表中的数据 来源:Pandas官网:https://pandas.pydata.org/docs/getting_started/intro_tutorials/index.html 笔记托管:https://gitee.com/DingJiaxiong/machine-learning-study 文章目录如何合并多个表中的数据导包数据准备【1】…

Linux系统基础——文件子系统

title: Linux系统文件子系统 date: 2022-12-18 15:48:24 modify: 2022-12-18 16:48:43 author: wangjianfeng tags: 001-computer-technology, OS, Linux aliases: Linux系统文件子系统 特此说明: 刘超的趣谈linux操作系统是比较重要的参考资料,本文大部分内容和图…

腾讯云轻量应用服务器搭建LAMP 开发环境

LAMP(LinuxApacheMySQLPHP)是目前国际流行的 Web 应用框架,包括了 Linux 操作系统、Apache Web 服务器、MySQL/MariaDB 数据库和 PHP 编程语言环境以及相关组件支持。 说明 LAMP 应用镜像底层基于 CentOS 7.6 64位操作系统。 登录 轻量应用服…

做一个极简 UI 库之代码 lint

eslint, prettier, stylelint 的配置 这三个规则的配置思路:代码美化用 prettier,逻辑代码用 eslint 校验,样式代码用 stylelint 校验。有跟代码美化冲突的以 prettier 为主 为什么要用这么多呢,因为 eslint 不能解析样式代码&a…

数据结构---LRU算法

LRU算法哈希链表自己的JAVA实现LRU全称Least Recently Used,也就是 最近最少使用的意思,是一种内存管理算法,该算法最早应用于Linux操作系统。这个算法基于一种假设:长期不被使用的数据,在未来被用到的几率也不大。因此…

【LeetCode】1754. 构造字典序最大的合并字符串

构造字典序最大的合并字符串 题目描述 给你两个字符串 word1 和 word2 。你需要按下述方式构造一个新字符串 merge :如果 word1 或 word2 非空,选择 下面选项之一 继续操作: 如果 word1 非空,将 word1 中的第一个字符附加到 mer…

node.js+uni计算机毕设项目基于微信小程序校园生活管理LW(程序+小程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置: Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等…

基于形态学处理的不规则形状图像的几何参数统计,包括输出面积,周长,圆度,矩形度,伸长度

up目录 一、理论基础 二、核心程序 三、测试结果 一、理论基础 形态学是图像处理中应用最为广泛的技术之一,主要用于从图像中提取对表达和描绘区域形状有意义的图像分量,使后续的识别工作能够抓住目标对象最为本质的形状特征,如边界和连通…

C#语言实例源码系列-实现文件分割和合并

专栏分享点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册 👉关于作者 众所周知,人生是一个漫长的流程,不断克服困难,不断反思前进的过程。在这个过程中…

腾讯云轻量应用服务器使用 WooCommerce 应用镜像搭建电商独立站

WooCommerce 是当前很受欢迎的电商独立站建站工具,具备开源、免费、使用简单且功能强大等特点,您可通过该镜像快速搭建基于 WordPress 的电商独立站。该镜像已预装 WordPress(包含 WooCommerce 插件)、Nginx、MariaDB、PHP 软件。…