vlan和vlanif

news2025/3/3 4:21:14

文章目录

  • 1、为什么会有vlan的存在
  • 2、vlan(虚拟局域网)
    • 1、vlan原理
      • 1. 为什么这样划分了
      • 2、如何实现不同交换机相同的vlan实现互访呢
      • 3、最优化的解决方法,vlan不同交换机
      • 4、vlan标签和vlan数据帧
    • 5、vlan实现
    • 2、基于vlan的划分方式
      • 1、基于接口的vlan划分方式
      • 2、基于mac地址划分
    • 3、以太网二层接口类型
      • 1、Access接口
      • 2、trunk接口
      • 3、Access和trunk接口
      • 4、hybrid接口
    • 4、vlan基础配置命令
      • 1、创建vlan
      • 1、Access接口配置
      • 2、Trunk接口配置
      • 3、hybrid接口配置
      • 4、总结vlan端口
    • 5、实验
      • 1、access和trunk接口
      • 2、对上面的实验的补充(不同vlan之间主机的通信)
        • 1、路由器物理接口
        • 2、路由器上面配置虚拟接口
        • 3、交换机实现路由功能(三层交换机这个就是,配置网关)-就解决掉了上面的问题了
    • 6、vlanif(虚拟局域网接口)
      • 1、vlanif实验和通信流程
      • 2、补充
    • 7、实验图片
    • 8、总结
      • 1、关于同网段的通信
      • 2、不同网段通信
      • 3、vlan
      • 4、vlanif

1、为什么会有vlan的存在

  • 交换机不能隔离广播域,如果广播域特别大的话,交换机泛洪的,就会传播到整个广播域

  • 广播域越大,产生的网络安全问题,垃圾流量问题就越严重

  • 因此就会有隔离广播域,路由器可以隔离,但是为了实现广播域的隔离,会增加很多的路由器,因此的话,不方便,就会在交换机上面实现广播域的隔离,不同的广播域在二层设备上面是不同的,这样泛洪的话,就不会泛洪到其他的广播域尚敏,这样的话就减少了广播域的规模

2、vlan(虚拟局域网)

1、vlan原理

  • 最常见的划分就是将交换机不同的端口划分到不同的vlan中

1. 为什么这样划分了

# mac地址表中就会记录mac,port,vlan

# 不同的vlan的区域的话,在vlan10中发送了一个广播的话,就只会在vlan10中泛洪,不会泛洪到vlan20中,这样的话,在通信的时候,首先发送的是arp请求是一个广播,但是不会泛洪到vlan20中,因此的话在默认的情况下,不同的vlan是无法进行通信的

# 交换机就实现了广播域的隔离


2、如何实现不同交换机相同的vlan实现互访呢

# 在vlan10中新添加一个端口也划分在vlan10中,然后另外一个交换机也配置一个端口在vlan10中,连接起来,从而实现了不同交换机中的相同vlan通信了

# 但是这个方法非常费端口

# 因此就有了下面的解决方法

3、最优化的解决方法,vlan不同交换机

img

# 就是在这个2个交换机上面打上2个口子,用于连接2个交换机的通信,这个线路vlan10和vlan20都可以在这个线路上面进行传输

# 比如A交换机发送一个数据,携带了vlan10这个数据,然后传输到B交换机,根据这个vlan信息的话,传输到vlan10里面去,这样的话,vlan20的标签也可以了

# 这样的端口称为trunk

# 在数据帧中添加vlan信息,可以跨交换机部署vlan

# 在逻辑上不同交换机上面相同的vlan是在连接在一个交换机上面

4、vlan标签和vlan数据帧

img

  • vlan标签就是能够使交换机分辨不同vlan的报文,需要在报文中添加vlan信息字段

  • vlan数据帧就是在帧上面的源mac地址后面添加vlan信息(802.1Q tag)

  • vlan标签上面详细的介绍

5、vlan实现

  • PC1发送数据,然后交换机打上标签,连接2个交换机的链路要承载多个vlan数据,所以需要基于vlan数据的标记,以便对不同的vlan数据帧进行区分

  • 就是在帧头插入802.1Q Tag

img

2、基于vlan的划分方式

  • 交换机打上tag的方法不一样

1、基于接口的vlan划分方式

  • 根据交换机的接口来划分vlan

  • 每个接口配置不同的pvid(port vlan id ),在接口划入到对应的vlan

  • vlan id 取值 1~4094

  • 每个端口默认的情况下是1

  • 数据帧会被打上pvid的tag

img

  • 主机移动的话,主机接入的接口就需要重新配置pvid

2、基于mac地址划分

img

  • mac和vlan id的映射关系

  • 主机移动,不需要重新配置vlan了,跟端口没有关系了

3、以太网二层接口类型

img

  • 都可以,图中的接口都可以改的

  • access 接口通常用于连接用户PC,服务器等终端设备接口,access接口连接的往往是收发无标记帧,access接口只能加入一个vlan中,也就是特定的vlan

1、Access接口

img

  • 接收帧

    • 当一个没有标签的数据帧进入这个接口,就会被vlan10打上标签

    • 如果数据帧的vlan10与接口的vlan10相同的话,直接进行交换机内部,接收该帧

    • 如果vlan20的数据帧的话,交换机不会接受这个数据帧,直接进行丢弃

  • 发送帧

    • 帧的vlan id与接口的vlan id相同的话,出交换机的时候,去掉vlan标签,然后从这个接口发送出去

    • 帧的vlan id 与 接口的 vlan id不同的话,禁止发送出去

2、trunk接口

img

  • 这个是一个干道口

  • vlan 1是默认的存在的

  • trunk这个通道相当于是一个控制规则,允许多个vlan通过

  • 发送帧

    • 接口接收到了数据,然后打上pvid,如果这pvid 在vlan列表中允许通过的话,就接收,不允许的话,就丢弃

    • 相同的vlan10发送的话,vlan id列表允许的这个vlan id的话,就通过,不允许就丢弃

  • 发送帧

    • 当vlan id相同的话,并且在vlan 列表的话,直接去掉vlan 标签,从这个接口发送出去

    • 数据帧的vlan id 与 接口的vlan id不同的话,但是在vlan 列表中的话,不去掉vlan 标签

    • 不在vlan 列表的话,不允许通过,禁止发送数据

3、Access和trunk接口

img

4、hybrid接口

img

  • 接收帧与trunk接口是一样的,但是了发送帧的话就不一样了,管理员能够决定这个数据帧发送出去的时候是保留这个vlan 信息还是去掉了,这个是由管理员进行决定的

  • 如果是untag类型的话,就是数据帧发送出去的时候需要去掉这个标签

  • tag类型的话,数据帧发送出去的时候不需要去掉这个标签

img

4、vlan基础配置命令

1、创建vlan

vlan 10
# 就直接进入了这个vlan视图了

# vlan id 取值范围是1~4094

# 创建多个vlan
vlan batch 20 30 40

# 批量创建vlan
vlan batch 20 to 30


1、Access接口配置

interface GigabitEthernet0/0/1
 port link-type access # 设置 access接口类型
 port default vlan 10  # 设置接口的vlan 

# 可以通过查看接口的pvid,也就是数据帧发送过来的时候,会被打上这个vlan 10的标签
[j1]display  interface g0/0/1

2、Trunk接口配置

interface GigabitEthernet0/0/2
 port link-type trunk  # 设置接口类型
 port trunk pvid vlan 10  # 设置pvid,也就是将这个接口加入到vlan中
 port trunk allow-pass vlan 10 20  # 主干通道允许 10 20 vlan 通过

3、hybrid接口配置

interface GigabitEthernet0/0/2
 port link-type hybrid # 默认就是这样类型的端口
 port hybrid pvid vlan 20   # 将接口加入到vlan 20中
 port hybrid untagged vlan 20 30  # 允许 vlan 20 30 通过

# 端口的类型
[j1]display  port vlan  active 
T=TAG U=UNTAG
-------------------------------------------------------------------------------
Port                Link Type    PVID    VLAN List
-------------------------------------------------------------------------------
GE0/0/1             hybrid       10      U: 1 10 30   # 10,30vlan标签,去掉标签,允许10 20 通过
GE0/0/2             hybrid       20      U: 1 20 30
GE0/0/3             hybrid       30      U: 1 10 20
                                         T: 30 # 出去的时候不需要去掉标签,允许10 20 30vlan出去



# vlan list
u 和 t 就是放行的vlan , u就是发出去去掉这个vlan 标签

4、总结vlan端口

img

# 总而言之,就是这个三个类型

# access接口 只能允许一种vlan通过,比较vid(数据携带的vlan id ) 和 pvid

# trunk接口 允许多种vlan通过,如果vid和pvid相同的哈,去掉标签,否则不去掉(vid在vlan 允许的情况下),不在话丢弃

# hybrid接口 允许多种vlan通过,可以自己控制是否去掉标签,在untag列表中,去掉标签,在tag列表中,携带标签发送,不在的列表中,丢弃

5、实验

1、access和trunk接口

img

# 实验目的

# 实现相同vlan主机访问

# 划分2个vlan

# 最上面的2个主机,通过pvid 1 来进行通信,什么都不用配置


  • 通信的原理

    • 首先ping 1.1.1.3
    # 携带的信息为 Dip 1.1.1.3 Sip 1.1.1.1 Dmac ffff Smac 有 
    
    • 通过s3上面的g2口,打上一个vlan10 的标签,然后通过查询规则,vlan 10 20都允许放行,arp会进行泛洪,但是g3口只允许vlan 20 通过,因此只能走 g1 口 到达下一个交换机 s1 上面

    • 然后继续到达s2交换机上面,通过查询vlan规则,走 g2 口到达 目标主机,记录了Dmac地址

    • 然后目标主机发送一个arp 应答,里面包含了

    DIp 1.1.1.1 Sip 1.1.1.3 Dmc 有 Smac 有
    
    
    • 然后这个交换机就会记录这一来一回的信息,也就是mac地址和port对应关系

    • 下一次就直接发送icmp包,进行通信即可

2、对上面的实验的补充(不同vlan之间主机的通信)

1、路由器物理接口

img

  • 实现不同vlan主机互访

  • 添加一个路由器,然后配置一个网关,充当一个网关,访问网关就相当于是访问同一个网段即可

  • 实现PC1与PC2或者PC4通信即可

  • 流程

# 访问不同的网段的时候,先要去寻找网关,arp解析网关mac地址,就有能力将数据送给网关,然后根据路由表寻找通往不同网段的ip地址,这样的话,就能寻找到不同的网段,实现了通信的效果

2、路由器上面配置虚拟接口
  • 当然上面的这种做法,容易费接口

  • 一个接口上面配置虚拟接口 .10 .20这样的,实现了逻辑口配置,绑定vlan ,只有虚拟接口才能实现vlan 标签,物理接口不能实现vlan 的绑定

  • dot1q ter vid 10,然后配置ip地址

  • 子接口不会开启arp服务,所以要开启arp br enable,物理接口默认是开启arp解析的

img

  • 路由器接收后,从对应的接口就发送一个数据帧,带有vlan 标签的
# 路由器r2配置文件
[r2-GigabitEthernet0/0/0.20]display  this
[V200R003C00]
#
interface GigabitEthernet0/0/0.20
 dot1q termination vid 20   # 通过绑定子接口vlan 10,来实现区分
 ip address 2.2.2.254 255.255.255.0 
 arp broadcast enable
#
return

# s1交换机的配置
[s1-GigabitEthernet0/0/3]display  this
#
interface GigabitEthernet0/0/3
 port link-type trunk
 port trunk allow-pass vlan 10 20
#
return

  • 缺点,这个路由器的线,非常的消耗带宽,性能上面的不足

  • 这个路由器上面的g0口的话,也可以作为一个网关,如果发送了一个数据没有携带vlan的话,g0口也可以作为一个网关,如果携带了vlan 1标签的数据的话,需要在g0口上面再来配置一个虚拟接口即可

3、交换机实现路由功能(三层交换机这个就是,配置网关)-就解决掉了上面的问题了
  • 具有路由功能就是一个三层交换机

img

  • 在交换机上面配置网关,使用的是vlanif ,抽象的逻辑接口

  • vlanif 后,就相当于路由功能

  • 配置一个vlanif 后,然后配置2个不同网段的网关即可

  • 这个S1就是一个汇聚层,S3和S2就是一个接入层

[s1]int Vlanif 10
[s1-Vlanif10]disp	
[s1-Vlanif10]display  this
#
interface Vlanif10
 ip address 1.1.1.254 255.255.255.0
#
return


[s1]int Vlanif 10
[s1-Vlanif20]disp	
[s1-Vlanif20]display  this
#
interface Vlanif20
 ip address 2.2.2.254 255.255.255.0
#
return

6、vlanif(虚拟局域网接口)

img

  • vlanif就相当于是一个路由功能,配置网关即可实现通信了

  • 实现了不同vlan之间的通信即可

1、vlanif实验和通信流程

img

# 首先2个交换机之间配置access接口,vlanif100 实现2个交换机之间的三层通信

# 然后ospf的配置,这样的话路由也都配置好了

# 通信的流程vlan标签的变化

# PC7与PC1之间的通信

# 首先PC7发送一个arp到网关解析到了网关mac地址,然后ping 1.1.1.1 经过g1口打上vlan 7的标签,然后S4解析发现不是自己的,发送到路由模块中去寻找,这个时候,发送与vlanif 100相匹配,去掉之前的标签,打上vlan 100标签发送出去,

# 到达了S1交换机,然后去掉自己vlan 100标签,匹配到了vlan if 10的路由了,打上vlan 10的标签,然后到了S3交换机上面了,达到出接口G2的时候去掉vlan 10的标签,到达了目标主机PC1

# 回包的时候也是这样的流程

2、补充

img

  • 加上了PC9,vlan10
# 这个时候交换机之间就不能使用access接口了,需要配置trunk接口

# 2个交换机配置这样的配置
# vlan 10用于二层的通信,100用于三层的通信
[s1-GigabitEthernet0/0/3]display  this
#
interface GigabitEthernet0/0/3
 port link-type trunk
 port trunk allow-pass vlan 10 100
#
return


# S4交换机上面的G3口的配置即可
[s4-GigabitEthernet0/0/3]display  this
#
interface GigabitEthernet0/0/3
 port link-type access
 port default vlan 10
#
return

7、实验图片

img

# 2个交换机上面配置ospf
# 如果2个交换机ospf中的范围不同的话,可能不会交换LSA信息

# 比如一个配置S1 1.1.1.1 0.0.0.0 另外一个配置S2 2.2.2.0 0.0.255

# 这样的话就是S1 是/32的,所以就会读取LSA,但是S2是/24,不会进行交换,这个就是范围不同导致的

8、总结

交换机通信原理
就是mac表
广播域等

1、关于同网段的通信

  • 发送arp请求解析mac地址后,开始通信

2、不同网段通信

  • 1.1.1.1 访问 2.2.2.2,先要去找1.1.1.1的网关做一个arp请求,解析到mac地址,不同网段需要网关,因此需要路由器,但是arp请求是广播域,路由器不接受,因此的话,在路由器上面配置网关,这样的话,就能访问到了网关,查找路由表,这个2个网段在不同的广播域中

  • 但是有特殊情况,2个不同的网关在同一个广播域中,这样的话,可以不设置网关,对目标ip发送一个arp请求,实现通信了

3、vlan

  • 交换机不能隔离广播域,因此设置vlan

  • 就是在接口上面配置vlan id 然后发送的数据经过这个接口就会被打上vlan标签,然后再来考虑放行

  • access接口类型的话,只能允许一个vlan通过,vlan丢弃

  • trunk接口类型的话,允许多个vlan通过,vlan ID 和 pvid一样的话,出去时去掉标签,不一样则不丢弃

  • hybrid接口类型的话,允许多个vlan通过,但是可以自己设置丢弃和不丢弃标签

4、vlanif

  • 交换机没有三层的能力,因此设置vlanif

  • 实现了路由的功能呢

  • vlan 100 vlanif 100对应的编号相同的

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

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

相关文章

遗传算法与深度学习实战(27)——进化卷积神经网络

遗传算法与深度学习实战(27)——进化卷积神经网络 0. 前言1. 自定义交叉算子2. 自定义突变操作符3. 进化卷积神经网络小结系列链接 0. 前言 DEAP toolbox 中提供的标准遗传操作符对于自定义的网络架构基因序列来说是不够的。这是因为任何标准的交叉算子…

react-dnd 拖拽事件与输入框的文本选中冲突

问题描述 当我们使用拖拽库的时候,往往会遇到拖拽的一个元素他的子孙元素有输入框类型的dom节点,当拖拽的事件绑定在该元素身上时候,发现子孙的输入框不能进行文本选中了,会按住鼠标去选中文本的时候会触发拖拽 实际的效果&…

经典NLP案例 | 推文评论情绪分析:从数据预处理到模型构建的全面指南

NLP经典案例:推文评论情绪提取 项目背景 “My ridiculous dog is amazing.” [sentiment: positive] 由于所有推文每秒都在传播,很难判断特定推文背后的情绪是否会影响一家公司或一个人的品牌,因为它的病毒式传播(积极&#xff0…

杨振宁大学物理视频中黄色的字,c#写程序去掉(原版改进,三)

上一节,我们分清了主次矛盾,并搞定了主要矛盾(去掉黄色的字),这一节解决次要矛盾(矩形色带)。 我们的想法如图: 1,我们找到稳定黄色的最左边,最右边两点&…

第24周:文献阅读

目录 摘要 Abstract 一、现有问题 二、提出方法 三、创新点 模型结构创新 强化学习与GAN结合 属性特征与通顺性优化 四、方法论 生成对抗网络(GAN) 强化学习(RL) 模型组件 五、实验研究 数据集 数据预处理 评价指…

SQL server学习05-查询数据表中的数据(上)

目录 一,基本格式 1,简单的SQL查询语句 2,关键字TOP 3,关键字DISTINCT 二,模糊查询 1,通配符 三,对结果集排序 1,不含关键字DISTINCT 2,含关键字DISTINCT 3&…

【Azure 架构师学习笔记】- Azure Function (1) --环境搭建和背景介绍

本文属于【Azure 架构师学习笔记】系列。 本文属于【Azure Function 】系列。 前言 随着无服务计算的兴起和大数据环境中的数据集成需求, 需要使用某些轻量级的服务,来实现一些简单操作。因此Azure Function就成了微软云上的一个必不可少的组成部分。 …

KeepAlive与RouterView缓存

参考 vue动态组件<Component>与<KeepAlive> KeepAlive官网介绍 缓存之keep-alive的理解和应用 Vue3Vite KeepAlive页面缓存问题 vue多级菜单(路由)导致缓存(keep-alive)失效 vue3 router-view keeperalive对于同一路径但路径…

Linux:进程(环境变量、程序地址空间)

目录 冯诺依曼体系结构 操作系统 设计操作系统的目的 操作系统的管理 进程 PCB fork 进程状态 进程状态查看 僵尸进程 孤儿进程 进程优先级 查看、修改进程优先级命令 竞争、独立、并行、并发 进程切换 活动队列和运行队列 活动队列 过期队列 active指针…

希迪智驾持续亏损8.2亿:毛利率下滑,冲刺“自动驾驶矿卡第一股”

《港湾商业观察》黄懿 近日,希迪智驾(湖南)股份有限公司(下称“希迪智驾”)向港交所主板递交上市申请,联席保荐人为中金公司、中信建投国际、中国平安资本(香港)。 资料显示&#…

Rust之抽空学习系列(三)—— 编程通用概念(中)

Rust之抽空学习系列(三)—— 编程通用概念(中) 1、变量&可变性 在Rust中,变量默认是不可变的 fn main() {let x 5;println!("x is {}", x); }使用let来声明一个变量,此时变量默认是不可变…

OpenCV中的识别图片颜色并绘制轮廓

一、实验原理 使用OpenCV库在图像中识别和绘制特定颜色(黄色)的轮廓 二、实验代码 import cv2 import numpy as np# 读取图片并调整大小 img cv2.imread(./color_1.png) img cv2.resize(img,(600,600))# 将图片从BGR颜色空间转换到HSV颜色空间 img_h…

【Qt】qt基础

目录 一、使用Qt Creator创建qt项目 二、项目文件解析 三、Qt中创建图形化界面的程序的两种方法 四、对象树 五、Qt中处理打印乱码问题的利器:qDebug() 一、使用Qt Creator创建qt项目 1.选择项目模板 选中第一类模板Application(Qt应用程序,包含普…

Transformer入门(6)Transformer编码器的前馈网络、加法和归一化模块

文章目录 7.前馈网络8.加法和归一化组件9.组合所有编码器组件构成完整编码器 7.前馈网络 编码器块中的前馈网络子层如下图所示: 图1.32 – 编码器块 前馈网络由两个带有ReLU激活函数的全连接层组成。全连接层(Fully Connected Layer)有时也…

AI智算-k8s部署大语言模型管理工具Ollama

文章目录 简介k8s部署OllamaOpen WebUI访问Open-WebUI 简介 Github:https://github.com/ollama/ollama 官网:https://ollama.com/ API:https://github.com/ollama/ollama/blob/main/docs/api.md Ollama 是一个基于 Go 语言开发的可以本地运…

HTML/CSS总结

HTML 1.1 标题标签h 为了使网页更具有语义化&#xff0c;我们经常会在页面中用到标题标签&#xff0c;HTML提供了6个等级的标题&#xff0c;即 标题标签语义&#xff1a; 作为标题使用&#xff0c;并且依据重要性递减 其基本语法格式如下&#xff1a; <h1> 标题文本…

信号处理:概念、技术、领域

目录 基本概念 主要技术 应用领域 信号处理是一个涉及分析、修改和再生信号的多学科领域。信号可以是各种形式的&#xff0c;例如声音、图像、视频或其他类型的监测数据。信号处理的主要目标是提取有用的信息并增强信号的质量。以下是信号处理的一些基本概念和应用&#xff…

黑盒白盒测试

任务1 黑盒测试之等价类划分法 【任务需求】 【问题】例&#xff1a;某报表处理系统要求用户输入处理报表的日期&#xff0c;日期限制在2003年1月至2008年12月&#xff0c;即系统只能对该段期间内的报表进行处理&#xff0c;如日期不在此范围内&#xff0c;则显示输入错误信息…

深度学习物体检测之YOLOV5源码解读

V5比前面版本偏工程化,项目化,更贴合实战 一.V5版本项目配置 (1)整体项目概述 首先github直接查找yolov5&#xff0c;下载下来即可。在训练时&#xff0c;数据是怎么处理的&#xff1f;网络模型架构是怎么设计的(如各层的设计)&#xff1f;yolov5要求是大于python3.8与大于等…

Go 怎么做性能优化芝麻开门篇

一、性能优化的流程 我们在对某个功能&#xff08;或单个接口&#xff09;做性能优化的时候。一般是该功能&#xff08;或接口&#xff09;性能无法满足我们的业务要求&#xff0c;所以被迫优化。在开始优化之前&#xff0c;我们需要明白一些理论知识。 1、常见的性能优化指标…