LAN 表示 Local Area Network ,本地局域网,通常使用 Hub 或者 Switch 来连接LAN 中的计算机。一般来说,两台计算机连入同一个 Hub 或者 Switch 时,他们就在同一个LAN中。
 
一个LAN 表示一个广播域。其含义是:LAN中的所有成员都会受到任意一个成员发出的广播包。
 
VLAN 表示 Virtual LAN。一个带有VLAN 功能的 Switch 能够将自己的端口划分出多个LAN。计算机发出的广播包可以被同一个LAN中的其他计算机收到,但位于其他LAN的计算机则无法收到。简单的说,VLAN将一个交换机分成了多个交换机,限制了广播的范围,在二层将计算机隔离到不同的VLAN中。
 
比方说,有两组机器,Group A 和 Group B ,我们想配置成Group A 中的机器可以互相访问,Group B 中的机器也可以互相访问,但是 Group A 和 Group B 中的机器无法互相访问。一种方法是使用两个交换机,A和B分别接到不同的交换机上。另一种方法是使用一个带VLAN功能的交换机,将 A 和 B的机器分别接到不同的VLAN中。
 
请注意,VLAN的隔离是二层上的隔离,A 和 B 无法互相访问指的是二层广播包(比如arp)无法跨域VLAN的边界。但在三成上(比如IP)是可以通过路由器让A 和 B 互通的。概念上一定要分清楚。
 
现在的交换机几乎都是支持VLAN的。通常交换机的端口有两种配置模式: Access 和 Trunk,如下图
 
 
Access 口
 
这些口被打上了VLAN的标签,表明该端口属于哪个VLAN。不同VLAN用VLAN ID 来区分,VLAN ID 的范围是 1- 4096 。Access 口都是直接与计算机网络相连的,这样从该网卡出来的数据包流入 Access口后就被打上了所在的VLAN 标签。Access 口只能属于一个VLAN。
 
Trunk 口
 
架设有两个交换机 A 和 B 。A上有 VLAN1(红)、VLAN2(黄)、VLAN3(蓝);B 上也有VLAN1、2、3,那如何让 AB 上相同的VLAN之间能够通信呢?
 
办法是将 A 和 B 连起来,而且连接 A 和 B 的端口要允许 VLAN1、2、3 这三个VLAN的数据通过。这样的端口就是 Trunk 口了。VLAN 1、2、3 的数据包在通过Trunk 口到达对方交换机的过程中始终带着自己的VLAN 标签。
 
了解了VLAN的概念之后,我们来看KVM虚拟化环境下是如何实现 VLAN 的,见下图
 
 
eth0 数宿主机上的物理网卡,有一个命名为 eth0.10的自身与之相连。
eth0.10 就是VLAN设备了,其VLAN ID 就是 VLAN10
eth0.10 古仔命名为 brvlan10 的Linux Bridge上,虚机VM1 的虚拟网卡vnet0也挂载brvlan10 上。
 
这样配置的效果就是:宿主机用软件实现了一个交换机(虚拟的),上面定义了一个VLAN10 。 eth0.10 、brvlan10 和 vnet0 都分别接到了 VLAN 10 的Access 口上。而eth0 就是一个 Trunk口。VM1 通过 vnet0 发出来的数据包会被打上 VLAN10 的标签。
 
eth0.10 的作用是:定义了VLAN10
 
brvlan10 的作用是:Bridge 上连接的其他设备自动加入到 VLAN10 中。
 
下面我们在增加一个 VLAN20 ,如图
 
 
这样虚拟交换机就有两个VLAN了,VM1 和 VM2分别属于 VLAN10 和 VLAN 20 。对于新创建的虚机,只需要将其虚拟网卡放入对应的 Bridge中,就能使用其所属的 VLAN。
 
VLAN 设备总是以母子关系出现,母子设备之间是一对多的关系。
 
一个母设备(eth0),可以有多个子设备(eth0.10  eth0.20 ....),而一个子设备只有一个母设备。

O012、Linux如何实现VLAN的更多相关文章

  1. Linux 如何实现 VLAN - 每天5分钟玩转 OpenStack(12)

    LAN 表示 Local Area Network,本地局域网,通常使用 Hub 和 Switch 来连接 LAN 中的计算机.一般来说,两台计算机连入同一个 Hub 或者 Switch 时,它们就在 ...

  2. Linux 如何实现 VLAN

    LAN 表示 Local Area Network,本地局域网,通常使用 Hub 和 Switch 来连接 LAN 中的计算机.一般来说,两台计算机连入同一个 Hub 或者 Switch 时,它们就在 ...

  3. Linux基础:VLAN篇

    一.二层基础知识 1.1 vlan介绍 本小节重点: vlan的含义 vlan的类型 交换机端口类型 vlan的不足 1.1.1 vlan的含义 局域网LAN的发展是VLAN产生的基础,因而先介绍一下 ...

  4. 动手实践 Linux VLAN - 每天5分钟玩转 OpenStack(13)

    本节我们来看如何在实验环境中实施和配置如下 VLAN 网络 配置 VLAN 编辑 /etc/network/interfaces,配置 eth0.10.brvlan10.eth0.20 和 brvla ...

  5. How to create vlan on Linux (with Cisco Catalyst Switch)

    In this article I want to share to you on how to create and configure vlan on Linux through Cisco Ca ...

  6. Linux实现的IEEE 802.q VLAN

    本文转载自: http://blog.chinaunix.net/uid-20786208-id-4291059.html Technorati 标签: Linux VLAN   ---------- ...

  7. vlan 以及 Linux实现的IEEE 802.1Q VLAN

    vlan 以及 Linux实现的IEEE 802.1Q VLAN Vlan的概念 VLAN技术介绍 VLANVLAN概述 以太网是一种基于CSMA/CD(Carrier Sense Multiple ...

  8. linux安装VLAN,系统怎么划分VLAN打标签上交换机

    前几天公司一台物理机需要连接公网,但是公网需要网卡打标签上去. 由于没有做过linux主机划分VLAN的操作,因此去查了一下,需要利用vconfig这个命令. 但是纠结的是,系统源中没有这个包.(很坑 ...

  9. 动手实践 Linux VLAN

    本节我们来看如何在实验环境中实施和配置如下 VLAN 网络 配置 VLAN 编辑 /etc/network/interfaces,配置 eth0.10.brvlan10.eth0.20 和 brvla ...

随机推荐

  1. 初识 Premiere

    本记录基于Premiere Pro CC 2015.3,编号不连贯,以视频编号为准,对应视频没有有用信息的没有记录. 1.3 基本工作界面和预设工作区 将面板独立出来:按住Ctrl拖动窗口 将关闭的面 ...

  2. Php+Redis函数使用总结

    因项目需求,冷落了redis,今天再重新熟悉一下: <?php //连接 $redis = New Redis(); $redis->connect('127.0.0.1','6379', ...

  3. selenium expected_conditions 源码学习记录

    #expected_conditions模块收集了一系列的场景判断方法 #源码地址 # https://seleniumhq.github.io/selenium/docs/api/py/_modul ...

  4. C++学习 之 初识头文件

    声明:            本人自学C++, 没有计算机基础,在学习的过程难免会出现理解错误,出现风马牛不相及的现象,甚至有可能会贻笑大方. 如果有幸C++大牛能够扫到本人的博客,诚心希望大牛能给予 ...

  5. 最详细React Native环境配置及项目初始化(2018-10-14)

    注意配环境一定要全程使用稳定VPN工具,否则会浪费大量时间!!!相信我 一.截止到项目初始化之前也就是执行这条命令之前都按官网的方法就可以 https://reactnative.cn/docs/ge ...

  6. 搭建与破解wiki (confluence)

    搭建环境: 操作系统:contos7 数据库:5.5.60-MariaDB java版本: jdk-11.0.2 confluence版本:confluence6.7.1 一. 准备工作 下载conf ...

  7. clientX和clientY属性需要注意的地方

    clientX和clientY为可视区鼠标的位置. 1. 随鼠标移动的div块[runjs] 当document有多个页面时,会出现问题.[runjs] 2. 解决方案:scrollTop, scro ...

  8. js Date格式转化

    Date格式转化为日期  年-月-日(格式随意修改) GetDateStr(dd, AddDayCount) { dd.setDate(dd.getDate() + AddDayCount)// 获取 ...

  9. 【HANA系列】【第三篇】SAP HANA XS的JavaScript安全事项

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列][第三篇]SAP HANA XS ...

  10. NOIp2013D2T3 华容道【搜索&图论-最短路】

    题目传送门 暴力搜索 看到这道题的第一反应就是直接上$bfs$啦,也没有想到什么更加优秀的算法. 然后就是$15$分钟打了$70$分,有点震惊,纯暴力诶,这么多白给分嘛,太划算了,这可是$D2T3$诶 ...