11-QinQ配置
本章节下载: 11-QinQ配置 (334.05 KB)
目 录
1.4.2 基于QoS策略配置外层VLAN Tag的添加策略
1.6.2 灵活QinQ配置举例一(基于端口配置外层VLAN Tag添加策略)
1.6.3 灵活QinQ配置举例二(基于QoS策略配置外层VLAN Tag添加策略)
QinQ是802.1Q in 802.1Q的简称,它是基于IEEE 802.1Q技术的一种二层隧道协议,通过将用户的私网报文封装上外层VLAN Tag,使其携带两层VLAN Tag穿越运营商的骨干网络(又称公网),从而为用户提供了一种比较简单的二层VPN隧道技术,也使运营商能够利用一个VLAN为包含多个VLAN的用户网络提供服务成为了可能。
IEEE 802.1Q定义的VLAN ID域只有12个比特,最多可以表示4094个VLAN。但在实际应用中,尤其是在城域网中,需要大量的VLAN来隔离用户,4094个VLAN远远不能满足需求。
QinQ使整个网络最多可提供4094×4094个VLAN,从而满足了城域网对VLAN数量的需求。它具备以下优点:
· 缓解公网VLAN ID资源日益紧缺的问题。
· 用户可以规划自己的私网VLAN ID,不会导致与公网VLAN ID冲突。
· 为小型城域网和企业网提供了一种简单、灵活的二层VPN解决方案。
· 当运营商升级网络时,用户网络不必更改原有配置,使用户网络具有了较强的独立性。
在公网的传输过程中,设备只根据外层VLAN Tag转发报文,并将报文的源MAC地址表项学习到外层VLAN Tag所在VLAN的MAC地址表中,而用户的私网VLAN Tag将被当作报文的数据部分进行传输。
图1-1 QinQ典型应用组网图
如图1-1所示,用户网络A和B的私网VLAN分别为VLAN 1~10和VLAN 1~20。运营商为用户网络A和B分配的公网VLAN分别为VLAN 3和VLAN 4。当用户网络A和B中带VLAN Tag的报文进入运营商网络时,报文外面就会被分别封装上VLAN 3和VLAN 4的VLAN Tag。这样,来自不同用户网络的报文在运营商网络中传输时被完全分开,即使这些用户网络各自的VLAN范围存在重叠,在运营商网络中传输时也不会产生冲突。当报文穿过运营商网络,到达运营商网络另一侧PE设备后,报文会被剥离运营商网络为其添加的公网VLAN Tag,然后再传送给用户网络的CE设备。
如图1-2所示,QinQ报文在运营商网络中传输时带有双层VLAN Tag
· 内层VLAN Tag:为用户的私网VLAN Tag,对应图中的Customer VLAN Tag,依靠该Tag在私网中传送QinQ报文。
· 外层VLAN Tag:为运营商分配给用户的公网VLAN Tag,对应图中的Service VLAN Tag,依靠该Tag在公网中传送QinQ报文,内层VLAN Tag在公网中被屏蔽。
图1-2 QinQ的报文结构
接口的MTU(Maximum Transmission Unit,最大传输单元)值默认为1500字节。由于为报文加上外层VLAN Tag后,报文长度将增加4个字节,因此建议用户适当增加运营商网络中各接口的MTU值(至少为1504字节)。
QinQ的实现方式可分为以下两种:
基本QinQ是基于端口方式实现的。当端口上配置了基本QinQ功能后,不论从该端口收到报文是否带有VLAN Tag,设备都会为该报文打上本端口缺省VLAN的Tag:
· 如果收到的是带有VLAN Tag的报文,该报文就成为带双Tag的报文;
· 如果收到的是不带VLAN Tag的报文,该报文就成为带有本端口缺省VLAN Tag的报文。
灵活QinQ是基于端口与VLAN相结合的方式实现的,它对QinQ的功能进行了扩展,是对QinQ的一种更灵活的实现。对于从同一个端口收到的报文,灵活QinQ可以为具有不同内层VLAN ID的报文添加不同的外层VLAN Tag。
通过使用灵活QinQ技术,在能够隔离运营商网络和用户网络的同时,又能够提供丰富的业务特性和更加灵活的组网能力。
仅S3100V2-EI系列交换机支持灵活QinQ。
如图1-3所示,是IEEE802.1Q协议定义的以太网帧的VLAN Tag结构,TPID(Tag Protocol Identifier,标签协议标识符)就是VLAN Tag中的一个字段,用于表示VLAN Tag的协议类型,IEEE 802.1Q协议规定TPID的取值为0x8100。
设备可以根据TPID值来识别报文中是否携带对应的VLAN Tag:当端口收到报文时,根据配置的TPID值与报文中相应的字段进行比较,如果二者一致,则表示报文中携带相应的VLAN Tag。例如,配置VLAN Tag中携带的TPID值为0x9100,而报文中实际携带的TPID值为0x8100,此时,设备就会认为报文中不携带VLAN Tag。
此外,第三方厂商的设备可能将QinQ报文外层VLAN Tag的TPID字段设为不同的值。为了与这些第三方厂商的设备兼容,用户可以通过修改TPID值,使发送到公网中的QinQ报文携带的TPID值与第三方厂商的相同,从而实现与这些厂商的设备互通。
由于TPID字段在以太网报文中的位置与不带VLAN Tag的报文中协议类型字段的位置相同,因此为了避免给报文转发和接收造成混乱,不允许用户将TPID值配置为表1-1中列举的常用协议类型值。
协议类型 |
协议类型值 |
ARP |
0x0806 |
PUP |
0x0200 |
RARP |
0x8035 |
IP |
0x0800 |
IPv6 |
0x86DD |
PPPoE |
0x8863/0x8864 |
MPLS |
0x8847/0x8848 |
IPX/SPX |
0x8137 |
IS-IS |
0x8000 |
LACP |
0x8809 |
802.1X |
0x888E |
集群 |
0x88A7 |
设备保留 |
0xFFFD/0xFFFE/0xFFFF |
与QinQ相关的协议规范有:
· IEEE 802.1Q:IEEE standard for local and metropolitan area networks: Virtual Bridged Local Area Networks
表1-2 QinQ配置任务简介
配置任务 |
说明 |
详细配置 |
配置基本QinQ功能 |
必选 |
|
配置灵活QinQ功能 |
可选 |
|
配置VLAN Tag中携带的TPID值 |
可选 |
· QinQ功能只需在运营商网络进行配置,用户网络不需进行配置。
· 对于QinQ的相关配置来说,以太网端口视图下的配置只对当前端口有效;二层聚合端口视图下的配置对当前聚合端口及其所对应聚合组中的所有成员端口都有效;端口组视图下的配置对当前端口组中的所有端口有效。
· 基本QinQ和灵活QinQ功能都应在连接用户网络的端口上进行配置。
使能了基本QinQ功能的端口将为其收到的报文添加新的VLAN Tag,该VLAN Tag即该端口缺省VLAN的Tag。
操作 |
命令 |
说明 |
|
进入系统视图 |
system-view |
- |
|
进入相应视图 |
进入二层以太网端口视图或二层聚合端口视图 |
interface interface-type interface-number |
二者必选其一 |
进入端口组视图 |
port-group manual port-group-name |
||
使能端口的基本QinQ功能 |
qinq enable |
必选 缺省情况下,端口的基本QinQ功能处于关闭状态 |
仅S3100V2-EI系列交换机支持本节所介绍的功能。
基本QinQ功能添加的外层VLAN Tag是端口缺省VLAN的Tag,灵活的QinQ功能则可以为不同的内层VLAN Tag添加不同的外层VLAN Tag。
· 基于端口配置外层VLAN Tag的添加策略
· 基于QoS策略配置外层VLAN Tag的添加策略
表1-4 配置外层VLAN Tag的添加策略
操作 |
命令 |
说明 |
|
进入系统视图 |
system-view |
- |
|
进入相应视图 |
进入二层以太网端口视图或二层聚合端口视图 |
interface interface-type interface-number |
二者必选其一 |
进入端口组视图 |
port-group manual port-group-name |
||
进入QinQ视图,并配置端口添加的外层VLAN Tag |
qinq vid vlan-id |
必选 缺省情况下,端口添加的外层VLAN Tag是端口缺省VLAN的Tag |
|
配置需添加外层VLAN Tag的内层VLAN Tag |
raw-vlan-id inbound { all | vlan-list } |
必选 |
一个内层VLAN Tag只能对应一个外层VLAN Tag。如果用户想改变报文的外层VLAN Tag,需要先删除旧的外层VLAN Tag配置,然后再配置新的外层VLAN Tag。
S3100V2-EI系列交换机也可以通过QoS策略的方式实现根据报文内层VLAN封装外层VLAN Tag的功能,请按照以下方法配置:
· 配置匹配报文原有VLAN Tag的流分类
· 配置封装外层VLAN Tag的流行为
· 将上述流分类和流行为在QoS策略中进行关联,然后将该QoS策略应用到全局入方向上
· 在设备连接用户网络侧端口上开启灵活QinQ功能,使全局配置的QoS策略在该端口生效。
表1-5 配置外层VLAN Tag的添加策略
操作 |
命令 |
说明 |
|
进入系统视图 |
system-view |
- |
|
创建类并进入类视图 |
traffic classifier classifier-name [ operator { and | or } ] |
必选 缺省情况下,类视图下各规则之间的关系为and,即逻辑与 |
|
配置匹配报文的规则,即指定报文的内层VLAN ID |
if-match customer-vlan-id vlan-id-list |
必选 |
|
退出至系统视图 |
quit |
- |
|
创建流行为并进入流行为视图 |
traffic behavior behavior-name |
必选 |
|
定义流行为,即指定为报文封装的外层VLAN ID |
nest top-most vlan-id vlan-id |
必选 |
|
退出至系统视图 |
quit |
- |
|
创建QoS策略并进入QoS策略视图 |
qos policy policy-name |
必选 |
|
将之前定义的流分类和指定的流行为进行绑定,组成QoS策略 |
classifier classifier-name behavior behavior-name |
必选 |
|
退出至系统视图 |
quit |
- |
|
全局应用QoS策略 |
qos apply policy policy-name global inbound |
必选 |
|
进入连接用户的二层以太网端口视图或端口组视图 |
进入二层以太网端口视图 |
interface interface-type interface-number |
二者必选其一 进入以太网端口视图后,下面进行的配置只在当前端口生效;进入端口组视图后,下面进行的配置将在端口组中的所有端口生效 |
进入端口组视图 |
port-group manual port-group-name |
||
开启端口的灵活QinQ功能 |
qinq enable downlink |
必选 |
关于QoS策略的更多详细信息,请参见“ACL和QoS配置指导”中的“QoS配置方式”部分。
表1-6 配置VLAN Tag中携带的TPID值
操作 |
命令 |
说明 |
进入系统视图 |
system-view |
- |
配置VLAN Tag中携带的TPID值 |
qinq ethernet-type hex-value |
可选 缺省情况下,VLAN Tag中所携带的TPID值都为0x8100 |
需要注意的是,全局配置的TPID值对所有端口均生效。
· 公司A的两个分支机构Site 1和Site 2通过运营商网络进行通信,该公司各业务使用的VLAN为VLAN 10~70;公司B的两个分支机构Site 3和Site 4也通过运营商网络进行通信,该公司各业务使用的VLAN为VLAN 30~90。
· PE 1和PE 2为运营商网络的边缘设备,且二者通过TPID值为0x8200的第三方厂商设备进行连接。
· 通过配置,利用运营商提供的VLAN 100使公司A的两个分支机构之间实现互通,利用运营商提供的VLAN 200使公司B的两个分支机构之间实现互通。
图1-4 基本QinQ配置组网图
用户必须通过配置保证运营商网络中的设备之间允许QinQ报文通过。
(1) 配置PE 1
· 配置端口Ethernet1/0/1
# 配置端口为Trunk端口,且允许VLAN 100的报文通过。
<PE1> system-view
[PE1] interface ethernet 1/0/1
[PE1-Ethernet1/0/1] port link-type trunk
[PE1-Ethernet1/0/1] port trunk permit vlan 100
# 配置端口的缺省VLAN为VLAN 100。
[PE1-Ethernet1/0/1] port trunk pvid vlan 100
# 使能端口的基本QinQ功能。
[PE1-Ethernet1/0/1] qinq enable
[PE1-Ethernet1/0/1] quit
· 配置端口Ethernet1/0/2
# 配置端口为Trunk端口,且允许VLAN 100和VLAN 200的报文通过。
[PE1] interface ethernet 1/0/2
[PE1-Ethernet1/0/2] port link-type trunk
[PE1-Ethernet1/0/2] port trunk permit vlan 100 200
# 配置端口添加的外层VLAN Tag的TPID值为0x8200。
[PE1-Ethernet1/0/2] quit
[PE1] qinq ethernet-type 8200
· 配置端口Ethernet1/0/3
# 配置端口为Trunk端口,且允许VLAN 200的报文通过。
[PE1] interface ethernet 1/0/3
[PE1-Ethernet1/0/3] port link-type trunk
[PE1-Ethernet1/0/3] port trunk permit vlan 200
# 配置端口的缺省VLAN为VLAN 200。
[PE1-Ethernet1/0/3] port trunk pvid vlan 200
# 使能端口的基本QinQ功能。
[PE1-Ethernet1/0/3] qinq enable
[PE1-Ethernet1/0/3] quit
(2) 配置PE 2
· 配置端口Ethernet1/0/1
# 配置端口为Trunk端口,且允许VLAN 200的报文通过。
<PE2> system-view
[PE2] interface ethernet 1/0/1
[PE2-Ethernet1/0/1] port link-type trunk
[PE2-Ethernet1/0/1] port trunk permit vlan 200
# 配置端口的缺省VLAN为VLAN 200。
[PE2-Ethernet1/0/1] port trunk pvid vlan 200
# 使能端口的基本QinQ功能。
[PE2-Ethernet1/0/1] qinq enable
[PE2-Ethernet1/0/1] quit
· 配置端口Ethernet1/0/2
# 配置端口为Trunk端口,且允许VLAN 100和VLAN 200的报文通过。
[PE2] interface ethernet 1/0/2
[PE2-Ethernet1/0/2] port link-type trunk
[PE2-Ethernet1/0/2] port trunk permit vlan 100 200
# 配置端口添加的外层VLAN Tag的TPID值为0x8200。
[PE2-Ethernet1/0/2] quit
[PE2] qinq ethernet-type 8200
· 配置端口Ethernet1/0/3
# 配置端口为Trunk端口,且允许VLAN 100的报文通过。
[PE2] interface ethernet 1/0/3
[PE2-Ethernet1/0/3] port link-type trunk
[PE2-Ethernet1/0/3] port trunk permit vlan 100
# 配置端口的缺省VLAN为VLAN 100。
[PE2-Ethernet1/0/3] port trunk pvid vlan 100
# 使能端口的基本QinQ功能。
[PE2-Ethernet1/0/3] qinq enable
[PE2-Ethernet1/0/3] quit
(3) 配置第三方厂商设备
对于PE 1与PE 2之间的第三方厂商设备,其关键配置如下:在连通PE 1与PE 2的端口上,都允许VLAN 100和200的报文携带VLAN Tag通过。
仅S3100V2-EI系列交换机支持本举例中的配置。
· 某公司的两个分支机构Site 1和Site 2通过运营商网络进行通信,该公司的语音和数据业务分别使用VLAN 10和VLAN 20加以区分。
· PE 1和PE 2为运营商网络的边缘设备,且二者通过TPID值为0x8200的第三方厂商设备进行连接。
· 通过配置,利用运营商提供的VLAN 100和VLAN 200分别使这两个分支机构间的语音和数据业务实现互通。
图1-5 灵活QinQ配置组网图
用户必须通过配置保证运营商网络中的设备之间允许QinQ报文通过。
(1) 配置PE 1
· 配置端口Ethernet1/0/1
# 配置端口为Hybrid端口,且允许VLAN 100和200的报文不带Tag通过。
<PE1> system-view
[PE1] interface ethernet 1/0/1
[PE1-Ethernet1/0/1] port link-type hybrid
[PE1-Ethernet1/0/1] port hybrid vlan 100 200 untagged
# 配置端口将来自VLAN 10的报文打上VLAN ID为100的外层VLAN Tag。
[PE1-Ethernet1/0/1] qinq vid 100
[PE1-Ethernet1/0/1-vid-100] raw-vlan-id inbound 10
[PE1-Ethernet1/0/1-vid-100] quit
# 配置端口将来自VLAN 20的报文打上VLAN ID为200的外层VLAN Tag。
[PE1-Ethernet1/0/1] qinq vid 200
[PE1-Ethernet1/0/1-vid-200] raw-vlan-id inbound 20
[PE1-Ethernet1/0/1-vid-200] quit
[PE1-Ethernet1/0/1] quit
· 配置端口Ethernet1/0/2
# 配置端口为Trunk端口,且允许VLAN 100和200的报文通过。
[PE1] interface ethernet 1/0/2
[PE1-Ethernet1/0/2] port link-type trunk
[PE1-Ethernet1/0/2] port trunk permit vlan 100 200
# 配置端口添加的外层Tag的TPID值为0x8200。
[PE1-Ethernet1/0/2] quit
[PE1] qinq ethernet-type 8200
(2) 配置PE 2
· 配置端口Ethernet1/0/1
# 配置端口为Hybrid端口,且允许VLAN 100和200的报文不带Tag通过。
<PE2> system-view
[PE2] interface ethernet 1/0/1
[PE2-Ethernet1/0/1] port link-type hybrid
[PE2-Ethernet1/0/1] port hybrid vlan 100 200 untagged
# 配置端口将来自VLAN 10的报文打上VLAN ID为100的外层VLAN Tag。
[PE2-Ethernet1/0/1] qinq vid 100
[PE2-Ethernet1/0/1-vid-100] raw-vlan-id inbound 10
[PE2-Ethernet1/0/1-vid-100] quit
# 配置端口将来自VLAN 20的报文打上VLAN ID为200的外层VLAN Tag。
[PE2-Ethernet1/0/1] qinq vid 200
[PE2-Ethernet1/0/1-vid-200] raw-vlan-id inbound 20
[PE2-Ethernet1/0/1-vid-200] quit
[PE2-Ethernet1/0/1] quit
· 配置端口Ethernet1/0/2
# 配置端口为Trunk端口,且允许VLAN 100和200的报文通过。
[PE2] interface ethernet 1/0/2
[PE2-Ethernet1/0/2] port link-type trunk
[PE2-Ethernet1/0/2] port trunk permit vlan 100 200
# 配置端口添加的外层Tag的TPID值为0x8200。
[PE2-Ethernet1/0/2] quit
[PE2] qinq ethernet-type 8200
(3) 配置第三方厂商设备
对于PE 1与PE 2之间的第三方厂商设备,其关键配置如下:在连通PE 1与PE 2的端口上,都允许VLAN 100和200的报文携带VLAN Tag通过。
仅S3100V2-EI系列交换机支持本举例中的配置。
· 某公司的两个分支机构Site 1和Site 2通过运营商网络进行通信,该公司的语音和数据业务分别使用VLAN 10和VLAN 20加以区分。
· PE 1和PE 2为运营商网络的边缘设备,且二者通过TPID值为0x8200的第三方厂商设备进行连接。
· 通过配置,利用运营商提供的VLAN 100和VLAN 200分别使这两个分支机构间的语音和数据业务实现互通。
图1-6 灵活QinQ配置组网图
用户必须通过配置保证运营商网络中的设备之间允许QinQ报文通过。
(1) 配置PE 1
· 配置端口Ethernet1/0/1
# 配置端口为Hybrid端口,且允许VLAN 100和200的报文不带Tag通过。
<PE1> system-view
[PE1] interface ethernet 1/0/1
[PE1-Ethernet1/0/1] port link-type hybrid
[PE1-Ethernet1/0/1] port hybrid vlan 100 200 untagged
[PE1-Ethernet1/0/1] quit
# 创建流分类规则,将来自Site 1的VLAN10的报文定义为“A10”类。
[PE1] traffic classifier A10
[PE1-classifier-A10] if-match customer-vlan-id 10
[PE1-classifier-A10] quit
# 定义流行为,为报文封装VLAN100的外层VLAN Tag,流行为命名为“P100”。
[PE1] traffic behavior P100
[PE1-behavior-P100] nest top-most vlan-id 100
[PE1-behavior-P100] quit
# 与以上配置类似,创建流分类“A20”匹配用户VLAN ID为20的报文,并创建流行为“P200”,为此类报文封装外层VLAN200的Tag。
[PE1] traffic classifier A20
[PE1-classifier-A20] if-match customer-vlan-id 20
[PE1-classifier-A20] quit
[PE1] traffic behavior P200
[PE1-behavior-P200] nest top-most vlan-id 200
[PE1-behavior-P200] quit
# 创建QoS策略,将流分类“A10”和流行为“P100”进行关联,将流分类“A20”和流行为“P200”关联,策略命名为“qinq”。
[PE1] qos policy qinq
[PE1-qospolicy-qinq] classifier A10 behavior P100
[PE1-qospolicy-qinq] classifier A20 behavior P200
[PE1-qospolicy-qinq] quit
# 在全局的接收方向应用“qinq”规则。
[PE1] qos apply policy qinq global inbound
# 使能端口的灵活QinQ功能。
[PE1] interface ethernet1/0/1
[PE1-Ethernet1/0/1] qinq enable downlink
· 配置端口Ethernet1/0/2
# 配置端口为Trunk端口,且允许VLAN 100和200的报文通过。
[PE1] interface ethernet 1/0/2
[PE1-Ethernet1/0/2] port link-type trunk
[PE1-Ethernet1/0/2] port trunk permit vlan 100 200
# 配置端口添加的外层Tag的TPID值为0x8200。
[PE1-Ethernet1/0/2] quit
[PE1] qinq ethernet-type 8200
(2) 配置PE 2
· 配置端口Ethernet1/0/1
# 配置端口为Hybrid端口,且允许VLAN 100和200的报文不带Tag通过。
<PE2> system-view
[PE2] interface ethernet 1/0/1
[PE2-Ethernet1/0/1] port link-type hybrid
[PE2-Ethernet1/0/1] port hybrid vlan 100 200 untagged
[PE2-Ethernet1/0/1] quit
# 创建流分类规则,将来自Site 2的VLAN10的报文定义为“A10”类。
[PE2] traffic classifier A10
[PE2-classifier-A10] if-match customer-vlan-id 10
[PE2-classifier-A10] quit
# 定义流行为,为报文封装VLAN100的外层VLAN Tag,流行为命名为“P100”。
[PE2] traffic behavior P100
[PE2-behavior-P100] nest top-most vlan-id 100
[PE2-behavior-P100] quit
# 与以上配置类似,创建流分类“A20”匹配用户VLAN ID为20的报文,并创建流行为“P200”,为此类报文封装外层VLAN200的Tag。
[PE2] traffic classifier A20
[PE2-classifier-A20] if-match customer-vlan-id 20
[PE2-classifier-A20] quit
[PE2] traffic behavior P200
[PE2-behavior-P200] nest top-most vlan-id 200
[PE2-behavior-P200] quit
# 创建QoS策略,将流分类“A10”和流行为“P100”进行关联,将流分类“A20”和流行为“P200”关联,策略命名为“qinq”。
[PE2] qos policy qinq
[PE2-qospolicy-qinq] classifier A10 behavior P100
[PE2-qospolicy-qinq] classifier A20 behavior P200
[PE2-qospolicy-qinq] quit
# 在全局的接收方向应用“qinq”规则。
[PE2] qos apply policy qinq global inbound
# 使能端口的灵活QinQ功能。
[PE2-Ethernet1/0/1] qinq enable downlink
· 配置端口Ethernet1/0/2
# 配置端口为Trunk端口,且允许VLAN 100和200的报文通过。
[PE2] interface ethernet 1/0/2
[PE2-Ethernet1/0/2] port link-type trunk
[PE2-Ethernet1/0/2] port trunk permit vlan 100 200
# 配置端口添加的外层Tag的TPID值为0x8200。
[PE2-Ethernet1/0/2] quit
[PE2] qinq ethernet-type 8200
(3) 配置第三方厂商设备
对于PE 1与PE 2之间的第三方厂商设备,其关键配置如下:在连通PE 1与PE 2的端口上,都允许VLAN 100和200的报文携带VLAN Tag通过。
不同款型规格的资料略有差异, 详细信息请向具体销售和400咨询。H3C保留在没有任何通知或提示的情况下对资料内容进行修改的权利!