《计算机网络微课堂》3-11 虚拟局域网 VLAN

news2024/9/21 10:42:21

本节课我们介绍虚拟局域网 VLAN 的基本概念。

3.11.1 虚拟局域网 VLAN 概述

在之前课程中我们已经介绍过了以太网交换机自学习和转发帧的流程,‍‍以及为避免网络环路而产生的生成树协议。

以太网交换机工作在数据链路层,‍‍也包括物理层,使用一个或多个以太网交换机互联起来的交换式以太网,其所有站点‍‍都属于同一个广播域。‍‍

随着交换式以太网规模的扩大,广播域相应扩大,如图所示,‍‍这是一个由多个以太网交换机互联而成的交换式以太网。‍‍每个以太网交换机上都连接了多个主机,‍‍形成了一个巨大的广播域。

然而巨大的广播域会带来很多弊端,例如广播风暴、‍‍难以管理和维护潜在的安全问题等。

‍‍我们来举例说明广播风暴的问题,‍‍假设网络中的某个主机‍‍要给另一个主机发送一个数据帧,但是在自己的 ARP 高速缓存表中,‍‍无法查到目的主机的 MAC 地址,于是首先要发送 ARP 广播请求来获取目的主机的 MAC 地址。‍‍该 ARP 广播请求会传遍整个网络,网络中的其他所有主机都可以收到该广播。‍‍这种情况就是所谓的广播风暴,广播风暴会浪费网络资源和网络中各主机的 CPU 资源,‍‍因此除非应用需求必须要使用广播,否则网络中的主机应尽量不使用广播。‍‍

也许有的同学会有这样的想法,‍‍如果网络中只是偶尔出现广播,那还是可以接受的,但事实上‍‍网络中会频繁出现广播信息。‍‍目前使用最广泛的 tcpip 协议当中的很多协议‍‍都会使用广播,例如地址解析协议 ARP,路由信息协议 rap‍‍,动态主机配置协议 dhcp 等。除此之外,其他一些协议站也会频繁使用广播。

那么‍‍如何才能将较大的广播域分割成更小的广播域?使用路由器就可以隔离广播域。如图所示,这是由两台以太网交换机互联而成的交换式以太网。‍‍网络中的各主机同属于一个广播域,使用路由器可以将该广播域分割成两个较小的广播域。‍‍路由器工作在网络体系结构的第三层,也就是网络层。

由于路由器默认情况下,‍‍不对广播数据包进行转发,因此路由器很自然的就可以隔离广播域。‍‍然而‍‍路由器的成本较高,局域网内部全部使用路由器来隔离广播域是不现实的。‍‍

在这种情况下,‍‍虚拟局域网技术应运而生,‍‍虚拟局域网的英文缩写词为 VLAN,它是一种将局域网内的设备‍‍划分成与物理位置无关的逻辑组的技术。这些逻辑组具有某些共同的需求。‍‍如图所示‍‍一楼、二楼、三楼分别有一个局域网,可将他们通过另外一个交换机互联成一个更大的局域网,‍‍那么原来每一个局域网成为现在局域网的一个网段,网络中的各主机属于同一个广播域,‍‍某个主机发送到广播数据包,其他所有主机都可以收到。

‍‍根据应用需求,‍‍我们将该局域网划分成两个 VLAN,VLAN1 和 VLAN1。此后‍‍VLAN1 中的广播数据包不会传送到 VLAN2,VLAN2 中的广播数据包也不会传送到 VLAN1,‍‍也就是说同一个 VLAN 内部可以广播通信,不同 VLAN 之间不能广播通信。

小结:

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

本节课我们介绍虚拟局域网 VLAN 的实现机制,‍‍虚拟局域网 VLAN 是在交换机上实现的,需要交换机能够实现以下两大功能:

  • 一个是能够处理带有 VLAN 标记的帧,也就是 IEEE 802.1Q 帧
  • 另一个是交换机的各端口,‍‍可以支持不同的端口类型,不同端口类型的端口,对帧的处理方式有所不同

我们首先来看‍‍ IEEE802.1q 帧,‍‍也称为 dot one q 帧。他对以太网的 MAC 帧格式进行了扩展,插入了四字节的 VLAN 标记,‍‍如图所示,这是以太网版本 2 的 MAC 格式,这是插入 VLAN 标记后的 802.1q 帧的格式:

VLAN 标记的最后 12 个比特称为 VLAN 标识符 vid,它唯一的标识了以太网帧属于哪一个 VLAN , ‍‍Vid 的取值范围是 0~4095,其中 0 和 4095 都不用来表示 VLAN,因此‍‍用于表示 VLAN 的 vid 的有效取值范围是 1~4094。

需要注意的是‍‍802.1q 帧是由交换机来处理的,而不是用户主机来处理的。‍‍当交换机收到普通的以太网帧时‍‍会将其插入四字节的 VLAN 标记,将其转变为 802.1q 帧,简称为打标签。‍‍

当交换机转发 802.1q 帧时,可能会删除其 4 字节 VLAN 标记,‍‍将其转变为普通以太网帧,简称为去标签,VLAN 标记字段的其他内容,‍‍对我们理解 VLAN 划分机制来说,并没有什么帮助,因此就要不再赘述了。‍‍


接下来我们介绍交换机的端口类型,交换机的端口类型一般有以下三种,它们分别是 Access,Trunk,Hybrid。

总结:

Access 接受没标签的,只转发同 ID 的,转发前去标签。

Trunk 总结:

  • 如果收到的帧 ID 值不相等,直接转发
  • 如果收到的帧 ID 相等,发送前去标签
  • 如果没有 ID,则打标签

需要说明的是思科交换机没有 Hybrid 端口。在介绍这三种交换机端口类型之前,我们首先需要了解一下端口的缺省 VLAN ID 这个概念,在思科交换机上将其称为本征 VLAN。

例如思科交换机在用户未配置 VLAN 时,所有端口都默认属于 VLAN1,即所有端口的本帧 VLAN 都是 VLAN1,而在华为交换机上将其称为端口 VLAN ID 剪辑为 PVID。 在我们接下来的介绍中,为了描述方便,我们采用 PVID 而不是本征 VLAN。需要注意的是交换机的每个端口,有且仅有一个 PVID:


接下来我们首先介绍 Access 端口,Access 端口一般用于连接用户计算机,只能属于一个 VLAN,因此 Access 端口的 PVID 值与端口所属 VLAN 的 ID 相同,如图所示主机 ABCD 分别连接在交换机的一个端口上,交换机首次上电时,默认配置各端口属于 VLAN1,也就是各端口的 PVID 值等于 1,默认配置各端口的类型为 Access,我们用大写字母 A 来表示。

Access 端口的接收处理方法是一般只接受未打标签的普通以太网 MAC 帧,根据接收帧的端口的 PVID 给帧打标签,即插入四字节 VLAN 标记字段,字段中的 VID 取值与端口的 PVID 取值相等。

我们来举例说明,假设主机 A 发送了一个广播帧,该帧从交换机的端口一进入交换机,由于端口一的类型是 Access,它会对接收到的未打标签的普通以太网 MAC 帧,打标签,也就是插入四字节的 VLAN 标记字段,如图所示,由于端口一的 PVID 值等于一,因此所插入的四字节 VLAN 记字段中的 VID 的值也等于 1。

Access 端口的发送处理方法是若帧中的 VID 与端口的 PVID 相等,则去标签后转发该帧,否则不转发。对于本例广播帧中的 VID 的取值与端口 234 的 PVID 取值都等于 1,因此交换机会从这三个端口对帧进行去标签转发。

总结:接受没标签的,转发同 ID 的


再来看这个例子,我们的应用需求是将主机 A 和 B 划归到 VLAN2,将 C 和 D 划归到 VLAN3,这样 VLAN2 中的广播帧不会传送到 VLAN3,VLAN3 中的广播帧也不会传送到 VLAN2,为了实现这种应用,可以在交换机上创建 VLAN2 和 VLAN3,然后将交换机的端口一和二划归到 VLAN2,因此端口 1 和 2 的 PVID 值等于 2,将交换机的端口 3 和 4 划归到 VLAN3,因此端口 3 和 4 的 PVID 值等于 3。

我们来看主机 A 发送广播帧的情况,该帧从交换机的端口 1 进入交换机,由于端口 1 的类型是 Access,它会对接收到的未打标签的普通以太网 MAC 帧打标签,也就是插入四字节的 VLAN 标记字段,如图所示,由于端口 1 的 PVI D 值等于 2,因此所插入的四字节 VLAN 标记字段中的 VID 的值也等于 2,广播帧中的 VID 的取值与端口二的 PVID 取值都等于 2,因此交换机会从端口二对帧进行去标签转发。


我们再来看主机 C 发送广播帧的情况,该帧从交换机的端口三进入交换机,由于端口三的类型是 Access,它会对接收到的未打标签的普通以太网 MAC 帧打标签,也就是插入四字节的 VLAN 标记字段,如图所示由于端口三的 PVID 值等于 3,因此所插入的四字节 VLAN 标记字段中的 VID 的值也等于 3,广播帧中的 VID 的取值与端口 4 的 PVID 取值都等于 3,因此交换机会从端口 4 对帧进行去标签转发。


接下来我们介绍 Trunk 端口,Trunk 端口一般用于交换机之间 或交换机与路由器之间的互联,使不同交换机的主机可以属于同个 VLAN。

Trunk 端口可以属于多个 VLAN,也就是说 Trunk 端口可以接收和发送多个 VLAN 的帧,用户可以设置 Trunk 端口的 PVID 值,默认情况下 Trunk 端口的 PVID 值为 1,

我们来举例说明 Trunk 端口的功能,如图所示,两台交换机互联而成了一个交换式以太网,我们的应用需求是将主机 ABEF 划归到 VLAN1,将主机 CDGH 划归到 VLAN2,由于交换机首次上电时默认配置各端口属于 VLAN1,其相应的 PVID 值等于 1,并且端口的类型为 Access,因此我们需要对交换机进行相应的配置,才能满足应用需求,分别在两个交换机上创建 VLAN2,并将他们的端口 3 和 4 都划归到 VLAN2,其相应的 PVID 值=2,而两个交换机的端口一和二保持默认配置即可,也就是属于 VLAN1,其相应的 PVID 值等于 1。

特别需要注意的是两个交换机互联的端口 5,需要将他们的类型更改为 Trunk 类型,而他们的 PVID 值保持默认的 1 即可。Trunk 端口的发送处理方法是对 VID 等于 PVID 的帧去标签再转发。假设主机 A 发送了一个广播帧,该帧从交换机一的端口 1 进入交换机,由于端口一的类型是 Access,它会对接收到的未打标签的普通以太网 MAC 帧打标签,也就是插入四字节的 VLAN 标记字段,如图所示。由于端口 1 的 PVID 值等于 1,因此所插入的四字节 VLAN 标记字段中的 VID 的值也等于 1。该广播帧中的 VID 的取值与端口二的 PVID 值都等于 1,端口二的类型是 Access,因此交换机一会从端口 2 对帧进行去标签转发

该广播帧中的 VID 的取值与端口 5 的 PVID 值都等于 1,端口 5 的类型是 Trunk,因此交换机一会从端口 5 对帧进行去标签转发,很显然该广播帧会从交换机 2 的端口 5 进入交换机二,Trunk 端口的接收处理方法是接收未打标签的帧,根据接收帧的端口的 PVID 给帧打标签,即插入四字节 VLAN 标记字段,字段中的 VID 取值与端口的 PVID 取值相等。对于本例交换机 2 会对接收到的未打标签的普通以太网 MAC 帧打标签,也就是插入 4 字节的 VLAN 标记字段。如图所示,由于端口 5 的 PVID 值等于 1,因此所插入的 4 自字节 VLAN 标记字段中的 VIP 的值也等于 1

该广播帧中的 VID 的取决与端口 1 和 2 的 PVID 值都等于 1,端口 1 和 2 的类型都是 Access,因此交换机 1 会从端口 1 和 2 对帧进行去标签转发。

总结:

  • 如果收到的帧 ID 值不相等,直接转发
  • 如果收到的帧 ID 相等,发送前去标签
  • 如果没有 ID,则打标签

再来看主机 C 发送广播帧的情况,该帧从交换机 1 的端口 3 进入交换机,由于端口三的类型是 Access,它会对接收到的未打标签的普通以太网 MAC 帧打标签,也就是插入四字节的 VLAN 标记字段。如图所示,由于端口 3 的 PVID 值=2,因此所插入的 4 自字节 VLAN 标标记字段中的 VID 的值也等于 2,该广播站中的 VID 的取值与端口 4 的 PVI D 值都等于 2,端口 4 的类型是 Access,因此交换机 1 会从端口 4 对帧进行去标签转发。

该广播帧中的 VID 的取值与端口 5 的 PVID 值不相等,由于 Trunk 端口对 VID 不等于 PVID 的,帧是直接转发的,因此交换机 1 会从端口 5 对帧直接转发,也就是不去掉标签,而带着标签直接转发。很显然该 802.1Q 广播帧会从交换机 2 的端口 5 进入交换机 2 Trunk 端口,接收已打标签的 802.1Q 帧,该广播帧中的 VID 的取值与端口 3 和 4 的 PVID 值都等于 2,端口 3 和 4 的类型都是 Access 类型,因此交换机二会从端口 3 和 4 对帧进行去标签转发。通过本例可以看出,再由多个交换机互联而成的交换式以太网装,划分 VLAN 时,连接主机的交换机端口,应设置为 Access 类型,交换机之间互联的端口应设置为 Trunk 类型。

接下来请同学们做一个练习题,以加深对 Access 端口和 Trunk、端口功能的理解。本题的答案如下所示,希望大家都能解答正确。

最后我们简单介绍一下华为交换机私有的 Hybrid 端口类型,Hybrid 的端口即可用于交换机之间或交换机与路由器之间的互联,这一点与 Trunk 端口相同,也可用于交换机与用户计算机之间的互联,这一点又与 Access 端口相同。

除此之外,Hybrid 端口的绝大部分功能与 Trunk 端口相同,不同点在于 Hybrid 端口的发送处理方法,Hybrid 的端口会查看帧的 VID 是否在端口的区域标签列表中,若存在则去标签后再转发,若不存在则直接转发。

接下来我们通过一个简单的应用实例来说明 Hybrid 端口的功能。主机 ABC 连接在同一个交换机的不同接口上,请利用 Hybrid 端口的功能实现以下应用需求,A 和 B 都能与 C 相互通信,但 A 与 B 不能相互通信,如图所示,

我们可以将这三台主机所连接的交换机的三个端口划分到不同的 VLAN,并且端口类型设置为 Hybrid。假设这三个 VLAN 分别是 VLAN10、VLAN20、VLAN30,相应的 PVID 分别为 10,20,30。

在端口一的区域标签列表中,配置 VLAN10 和 VLAN30。

在端口二的去标签列表中配置 VLAN20 和 VLAN30,在端口三的去标签列表中配置 VLAN10,VLAN20,VLAN30,主机 A 给 C 发送数据帧,该帧从交换机的端口 1 进入交换机,由于端口 1 的类型是 Hybrid 的,他会对接收到的未打标签的普通以太网 MAC 帧打标签,也就是插入四字节的 VLAN 标记字段,如图所示,由于端口一的 PVID 值等于 10,因此所插入的四字节 VLAN 标记字段中的 VID 的值也等于 10,该帧将从端口三转发,由于帧中的 VID 的取值在端口 3 的区标签列表中,因此该帧会被去标签转发,这样主机 C 就可以收到主机 A 发送的数据帧。

同理,主机 C 给 A 发送数据帧,主机 A 同样可以收到,我们就要不再演示了。

那么主机 B 给 C 发送数据帧的具体过程又如何呢?如图所示。

同理,主机 C 给 B 发送数据帧,主机 B 同样可以收到,我们就要不再演示了。

再来看看主机 A 给 B 发送数据帧的情况,该帧从交换机的端口一进入交换机,给该帧打标签,其中 VIP 取值为 10,该帧将从端口 2 转发,由于帧中的 VID 的取值,不在端口 2 的去标签列表中,因此该帧被直接转发,这样主机 B 就会收到一个带有 VLAN 标记的 802.1Q 帧,但是主机 B 可以识别普通以太网 MAC 帧,而不能识别 802.1Q 帧,只能丢弃该帧。

同理,主机 B 给 A 发送的普通以太网 MAC 帧,主机 A 收到的却是 802.1Q 帧,无法识别而丢弃。

本节课的内容小结如下:

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

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

相关文章

兴业证券 | 哪些行业在提价?

一方面, 部分行业年初以来PPI价格整体上涨,4月进一步提价;另一方面,部分行业年初以来PPI价格整体下跌或者涨幅不高,但4月开始出现边际提升。 前言:年初以来,“提价”是一条重要的投资线索。我们…

【找出满足差值条件的下标 I】python

目录 暴力题解 优化:滑动窗口维护大小值 暴力题解 class Solution:def findIndices(self, nums: List[int], indexDifference: int, valueDifference: int) -> List[int]:nlen(nums)for i in range(n):for j in range(n-1,-1,-1):if abs(i-j)>indexDiffere…

千亿级开源大模型Qwen110B部署实测

近日,通义千问团队震撼开源 Qwen1.5 系列首个千亿参数模型 Qwen1.5-110B-Chat。 千亿级大模型普通显卡是跑不了推理的,普通人一般也没办法本地运行千亿级大模型。 为了探索千亿级大模型到底需要计算资源,我用云计算资源部署了Qwen1.5-110B-…

安装qianfan大模型库,报错:ERROR: Command errored out with exit status 1

安装qianfan大模型库(pip install qianfan),报错:ERROR: Command errored out with exit status 1 分析错误,是加载 pycryptodome库时导致的 解决: 1、命令行中重新安装:>pip install pycry…

uniapp+vue3+ts开发小程序或者app架构时候的UI框架选型

使用vue3tsviteuniapp开发小程序或者跨平台app的趋势越来越高,有一个顺手的UI的框架还是非常重要的,官方维护的 uni-ui,支持全端,而且有类型提示,目前已经内置到 GitHub - Sjj1024/uniapp-vue3: 使用uniapp和vue3 ts …

4、PHP的xml注入漏洞(xxe)

青少年ctf&#xff1a;PHP的XXE 1、打开网页是一个PHP版本页面 2、CTRLf搜索xml&#xff0c;发现2.8.0版本&#xff0c;含有xml漏洞 3、bp抓包 4、使用代码出发bug GET /simplexml_load_string.php HTTP/1.1 补充&#xff1a; <?xml version"1.0" encoding&quo…

云计算-No-SQL 数据库 (No-SQL Database)

DynamoDB简介 (Introduction to DynamoDB) AWS DynamoDB 是亚马逊提供的一种 NoSQL 数据库&#xff0c;适用于需要快速访问的大规模应用程序。NoSQL 数据库指的是非关系型数据库&#xff08;或许应该称为“非关系数据库”&#xff09;。关系型数据库是你之前可能使用过的熟悉的…

如何恢复未保存/误删除的Excel文档?

想象一下&#xff0c;您已经在一个非常重要的 Excel 上工作了几个小时&#xff0c;而您的计算机卡住了&#xff0c;您必须重新启动计算机。Excel 文件未保存/误删除&#xff0c;您只是因为忘记点击保存按钮而损失了数小时的工作时间。但是&#xff0c;当您意识到一小时前在 Exc…

校园招新之获取进QQ群但未报名人员

校园的社团、实验室招新一般由是校领导会发一个QQ通知&#xff0c;让各个班的同学们进一个招新群。 群里面会有负责人提示大家报名&#xff0c;但是群成员不总是都会报名&#xff0c;我们需要的就是&#xff0c;找到那些&#xff0c;已经进群&#xff0c;但是没有报名的同学&am…

SketchUp v2024 v24.0.553 解锁版安装教程 (强大的绘图三维建模工具)

前言 SketchUp&#xff08;简称SU&#xff0c;俗称草图大师&#xff09;全球知名的三维建模软件&#xff0c;强大的绘图工具、建模渲染、扩展插件和渲染器模板、海量3D模型库及建模灯光材质渲染效果图&#xff0c;用于建筑师、城市规划专家、游戏开发等行业。 一、下载地址 …

一行代码实现UI拖拽的效果

演示 先来看效果吧&#xff01; 实现方式 1.首先创建一个你想拖动的UI图片 2.创建一个C#的脚本 3.编写控制脚本&#xff08;代码按我的敲就行&#xff09; 付上代码片段 public void OnDrag(PointerEventData eventData){transform.position eventData.position;} 4.添加脚…

linux系统——top资源管理器

在linux系统中&#xff0c;有类似于windows系统中的资源管理器&#xff0c;top用于实时的监控系统的任务执行状态以及硬件配置信息 在linux中&#xff0c;输入top命令&#xff0c;可以进入相应界面&#xff0c;在此界面可以使用一些指令进行操作 如&#xff0c;输入z 可以改变…

github加速访问及资源一秒代理下载

如果你想加速打开github网页&#xff0c;可以采用以下方法&#xff0c;仅需一个插件。 1.代理加速访问 打开gitee网站&#xff0c;搜索dev-sidecar关键字&#xff0c;然后找到星星最多的项目 可以阅读项目说明&#xff0c;找到感兴趣的内容或是直接下载DevSidecar桌面应用程序…

stm32学习-流水灯

接线 注意&#xff1a;LED灯长一点的引脚是正极。 配置GPIO 1.使用RCC开启GPIO时钟 void RCC_AHBPeriphClockCmd(uint32_t RCC_AHBPeriph, FunctionalState NewState); void RCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState); void RCC_APB1Perip…

电子电器架构 - 车载网管功能简介

电子电器架构 - 车载网管功能简介 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,…

OZONBIGSELL分析产品工具,OZON平台数据分析

在当今的数字化时代&#xff0c;电商平台的竞争日趋激烈&#xff0c;数据成为了企业决策的重要支撑。OZON作为俄罗斯领先的电商平台&#xff0c;其背后蕴含的海量数据对于卖家而言&#xff0c;既是挑战也是机遇。接下来看看OZONBIGSELL这一分析产品工具&#xff0c;以及如何利用…

【实战教程】使用Spring AOP和自定义注解监控接口调用

一、背景 随着项目的长期运行和迭代&#xff0c;积累的功能日益繁多&#xff0c;但并非所有功能都能得到用户的频繁使用或实际上根本无人问津。 为了提高系统性能和代码质量&#xff0c;我们往往需要对那些不常用的功能进行下线处理。 那么&#xff0c;该下线哪些功能呢&…

C从零开始实现贪吃蛇大作战

个人主页&#xff1a;星纭-CSDN博客 系列文章专栏 : C语言 踏上取经路&#xff0c;比抵达灵山更重要&#xff01;一起努力一起进步&#xff01; 有关Win32API的知识点在上一篇文章&#xff1a; 目录 一.地图 1.控制台基本介绍 2.宽字符 1.本地化 2.类项 3.setlocale函…

原生标签WebComponent

文章目录 介绍一、web Component二、怎么使用三、在Vue中使用使用场景 前端必备工具推荐网站(免费图床、API和ChatAI等实用工具): http://luckycola.com.cn/ 介绍 平常浏览各个网站过程中&#xff0c;经常遇到的一种现象&#xff1a;页面广告。 这种广告按照来源可分为两种&…

Python TinyDB库:轻量级NoSQL数据库的终极指南

更多Python学习内容&#xff1a;ipengtao.com TinyDB是一个轻量级的NoSQL数据库&#xff0c;适用于需要嵌入式数据库的小型项目。它使用JSON文件存储数据&#xff0c;并提供了简单易用的API&#xff0c;支持多种查询和索引操作。TinyDB非常适合那些不需要复杂数据库功能的小型应…