版权声明: https://blog.csdn.net/xinyuan510214/article/details/52020987

本文乃fireaxe原创,使用GPL发布,可以自由拷贝,转载。但转载请保持文档的完整性,并注明原作者及原链接。内容可任意使用,但对因使用该内容引起的后果不做任何保证。
作者:fireaxe_hq@hotmail.com
博客:fireaxe.blog.chinaunix.net

l  Vlan原理

Ø  Vlan介绍

Ø  汇聚链接

Ø  802.1Q协议

Ø  QinQ

l  交换机实现

Ø  交换机要做什么

Ø  Ingress vlan处理

Ø  Egress vlan处理

Vlan介绍--概念

n  VLAN(Virtual Local Area Network)的中文名为“虚拟局域网”,遵循IEEE802.1Q协议。

n  VLAN是一种将局域网设备从逻辑上划分成一个个网段,从而实现虚拟工作组的数据交换技术。

n  Vlan的优点

广播风暴防范

网络安全

成本降低:

普通的交换机如下图所示:

所有的端口都在同一个广播域,任何一个端口发送的广播报文都会被发送到所有端口。这样显然不利于网络的隔离,还有可能会出现网络风暴(如arp等报文)。为了避免这些问题,通常的办法是把不同的组放到不同的交换机上,如每个办公室属于一个交换机。交换机之间通过路由器连接。这样可以在一定程度上避免广播风暴。但假如我们使用20口的交换机,而每个房间只有四、五个用户,显然每个房间使用一个交换机有些浪费了。如果能在同一个交换机上实现端口的分组,那就太好了。

如下图所示,我们把交换机划分为两个区域。

这样做的效果与使用两个小一些的交换机是一样的,但组网形式就灵活多了。假如某天需要调整端口的分配,不需要重新购买新的设备,只需要在交换机上配一下。

上面所说的就是vlan 的概念,每个vlan代表一个组。

再考虑另一个问题,交换机互联。

如果我们30台电脑,这就需要两个20口的交换机级联起来。假如此时需要vlan,而每个vlan的电脑都分布在两个交换机上,该如何组网?

可以想见,我们需要通过下面的形式组网。这样如果A需要发送报文到C,则可以通过互联的蓝色端口把报文从交换机1转发到交换机2。这显然有个问题存在,每个vlan都需要一个单独的端口用户交换机级联,显然有些浪费。如果能通过一个口把所有数据都通过一个口发送就好了。

如下图所示,这可行吗?只有一个障碍,交换机如何知道其他交换机转发来的报文是属于哪个vlan的?

办法很简单,在报文中增加一个字段用户区分,在vlan中称为tag。这就是vlan协议的由来。而由此也产生了两种端口:trunk与access。access口用于连接pc机,这个口显然只能属于一个vlan,而且入口与出口都不需要附加tag。trunk口用户交换机互联,这个口可能会属于多个vlan,而且报文进出都需要带tag。

vlan的实现是802.1Q协议,它完成下面的几项工作:

1. 通过在报文中添加字段,支持多个交换机之间的组网

2. 该字段需要有独特的标识

3. 该字段中应该有vlan ID

QinQ技术:

n  QinQ技术(也成stacked vlan 或 double lan)。 标准出自IEEE802.1ad。其实现将用户私网Vlan Tag封装在公网Vlan Tag中,是报文带着两层Vlan Tag穿越运营商的骨干网络(公网)

n  优点: 缓解日益紧缺的公网VLAN ID资源问题,用户可以规划自己的私网VLAN ID,不会导致和公网VLAN ID冲突

其组网形式如下图所示:

根据上述内容,显然所有功能都需要依靠vlan的tag来实现,而tag不是生来就有的。要实现tag的添加,交换机(switch)显然有些工作是必须要做的:

n  为进入switch的untagged报文增加tag

n  为进入switch的为Ctag的报文增加Stag

n  删除从switch出去的Stag报文的Stag

n  删除从switch出去的Double tag报文的Stag

n  保证带某个Vlan ID的报文只在属于该vlan的ports中发送

根据这些功能的要求,可以画出入口与出口的功能能框图:

根据原始的vlan需求,显然tag是通过端口号添加的,但随着发展,vlan tag的添加也丰富了起来。到目前为止,常见的tag添加方法有根据mac添加、根据protocol添加、根据port添加三种。同时增加的还有vlan翻译功能,也就是说可以对用户所带的tag进行改变。

报文进入switch时,首先会判断是否带有tag,如果有则直接进入下面的L2转发流程。如果没有tag,会查找mac vlan翻译表,根据报文的源mac地址查找是否在mac vlan表中有记录,如果有则进入L2转发流程,否则继续检测protocol。在proctocol vlan中查找后,如果还是没有,则会根据端口号打上一个tag,然后进入L2转发流程。

综上,进入L2转发的报文是一定带tag的。

VLAN入门知识的更多相关文章

  1. [置顶] Mysql存储过程入门知识

    Mysql存储过程入门知识 #1,查看数据库所有的存储过程名 #--这个语句被用来移除一个存储程序.不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程 #SELECT NAME FROM ...

  2. 移动H5开发入门知识,CSS的单位汇总与用法

    说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着手机的流行,web app和hybrid a ...

  3. H5移动端开发入门知识以及CSS的单位汇总与用法

    说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着手机的流行,web app和hybrid a ...

  4. Java web 入门知识 及HTTP协议详解

     Java  web  入门知识 及HTTP协议详解 WEB入门 WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. Internet上供外界访问的Web资 ...

  5. Java基础入门知识

    Java编程入门知识   知识概要: (1)Java入门基本常识 (2)Java的特性跨平台性 (3)Java的编程环境的搭建 (4)Java的运行机制 (5)第一个Java小程序入门 (1)Java ...

  6. zabbix入门知识

    zabbix入门知识 zabbix中文手册 https://www.zabbix.com/documentation/3.4/manual/ 1.zabbix介绍 Zabbix 是一个企业级的分布式开 ...

  7. React的入门知识与概念【1】

    回顾在以往的项目开发中,从最初的使用的原生html+js+css+jquery开发,到后来随着项目功能的增加,也渐渐学习了Vue.js框架的开发,以及Vue.js的全家桶Axios,Vue-route ...

  8. 我的Python笔记补充:入门知识拾遗

    声明:本文整理借鉴金角大王的Python之路,Day1 - Python基础1,仅供本人学习使用!!! 入门知识拾遗 一.bytes类型 二.三元运算 1 result = 值1 if 条件 else ...

  9. 浅谈TCP IP协议栈(一)入门知识【转】

    说来惭愧,打算写关于网络方面的知识很久了,结果到今天才正式动笔,好了,废话不多说,写一些自己能看懂的入门知识,对自己来说是一种知识的总结,也希望能帮到一些想了解网络知识的童鞋. 万事开头难,然后中间难 ...

随机推荐

  1. 天河2号-保持使用yhrun/srun时连接不中断 (screen 命令教程 )

    问题重述: 当我们使用天河机进行并行程序实验的时候,都会使用到yhrun/srun命令.在超算环境下,yhrun 命令用来进行提交交互式作业,有屏幕输出.但是容易受到网络波动影响导致断网或者关闭窗口最 ...

  2. C#程序如何捕捉未try/catch的异常——不弹“XXX已停止工作”报错框

    诚意满满直接上代码: static void Main(string[] args) { //Main函数中增加此句 AppDomain.CurrentDomain.UnhandledExceptio ...

  3. zabbix之运维疑难总结

    2.trousers包 zabbix默认情况下要求trousers包的版本是0.3.12版本以上.如果低于这个版本,有可能zabbix-server服务启动不成功.在mysql7.1版本以上可能会使用 ...

  4. BZOJ4735:你的生命已如风中残烛(组合数学)

    Description 众所周知,萌萌哒六花不擅长数学,所以勇太给了她一些数学问题做练习.但是今天六花酱不想做数学题,于是他们开始打牌. 现在他们手上有m张不同的牌,牌有两种:普通牌和功能牌.功能牌一 ...

  5. RMAN删除备份

    删除备份--DELETE命令 用于删除RMAN备份记录及相应的物理文件.当使用RMAN执行备份操作时,会在RMAN资料库(RMAN Repository)中生成RMAN备份记录,默认情况下RMAN备份 ...

  6. 20165302Exp0 Kali安装 Week1

    一,下载 下载网址https://www.kali.org/downloads/ 二,安装(安装过程中有一部分没有截图,因此没有贴上) 创建虚拟机 选择Linux,版本Ubuntu 一直下一步,最后点 ...

  7. Android Environment 获取各种路径的方法

    <pre name="code" class="java">package com.deepoon.beyond.environment; impo ...

  8. 调用类java.lang.Math的成员方法"public static double random"运算下面表达式10000次,统计其中生成的整数0,1,2,.....20的个数分别是多少,并输出统计结果.(int)(Math.random()*20+0.5)

    public class Test2 { public static void main(String args[]){ int num; int count[]=new int[21]; for(i ...

  9. js阻止事件冒泡的两种方法

    1.什么是JS事件冒泡 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这 ...

  10. 支持向量机通俗导论(理解SVM的三层境界)【非原创】

    支持向量机通俗导论(理解SVM的三层境界) 作者:July :致谢:pluskid.白石.JerryLead. 出处:结构之法算法之道blog. 前言 动笔写这个支持向量机(support vecto ...