4.4. 扁平提供商网络数据包流的工作方式是什么?
本节介绍了如何将流量流进到具有扁平供应商网络配置的实例。
扁平提供商网络中的传出流量流
下图描述了离开实例的流量的数据包流,直接到达外部网络。配置 br-ex
外部网桥后,将物理接口添加到网桥,并将实例生成到 Compute 节点后,生成的接口和网桥配置类似于下图中的配置(如果使用 iptables_hybrid
防火墙驱动程序):
-
数据包离开实例的
eth0
接口,并到达 linux 网桥qbr-xx
。 -
网桥
qbr-xx
连接到br-int
,使用 veth 对qvb-xx <-> qvo-xxx
。这是因为网桥用于应用安全组定义的入站/出站防火墙规则。 -
接口
qvb-xx
连接到qbr-xx
linux 网桥,qvoxx
连接到br-int
Open vSwitch (OVS) 网桥。
'qbr-xx'Linux 网桥配置示例:
brctl show
# brctl show
qbr269d4d73-e7 8000.061943266ebb no qvb269d4d73-e7
tap269d4d73-e7
br-int
上的 qvo-xx
配置:
端口 qvo-xx
使用与扁平提供商网络关联的内部 VLAN 标签标记。在本例中,VLAN 标签是 5
。当数据包到达 qvo-xx
时,VLAN 标签将附加到数据包标头中。
数据包然后被移到 br-ex
OVS 网桥,使用 patch-peer int-br-ex <-> phy-br-ex
。
br-int
上的 patch-peer 配置示例:
br-ex
上 patch-peer 配置示例:
当此数据包到达 br-ex
上的 phy-br-ex
时,br-ex
中的 OVS 流会剥离 VLAN 标签(5),并将它转发到物理接口。
在以下示例中,输出中的 phy-br-ex
的端口号显示为 2
。
以下输出显示了到达 phy-br-ex
(in_port=2
)的数据包,其 VLAN 标签为 5
(dl_vlan=5
)。此外,br-ex 中的 OVS 流将剥离 VLAN 标签,并转发数据包到物理接口。
ovs-ofctl dump-flows br-ex
# ovs-ofctl dump-flows br-ex
NXST_FLOW reply (xid=0x4):
cookie=0x0, duration=4703.491s, table=0, n_packets=3620, n_bytes=333744, idle_age=0, priority=1 actions=NORMAL
cookie=0x0, duration=3890.038s, table=0, n_packets=13, n_bytes=1714, idle_age=3764, priority=4,in_port=2,dl_vlan=5 actions=strip_vlan,NORMAL
cookie=0x0, duration=4702.644s, table=0, n_packets=10650, n_bytes=447632, idle_age=0, priority=2,in_port=2 actions=drop
如果物理接口是另一个 VLAN 标记的接口,则物理接口将标签添加到数据包。
扁平提供商网络中传入流量流
本节包含有关来自外部网络的传入流量流的信息,直到到达实例的接口。
-
传入流量到达物理节点上的
eth1
。 -
数据包传递到
br-ex
网桥。 -
数据包通过 patch-peer
phy-br-ex <--> int-br-ex
移到br-int
。
在以下示例中,int-br-ex
使用端口号 15
。查看包含 15 (int-br-ex)
的条目:
观察 br-int 上的流量流
当数据包到达
int-br-ex
时,br-int
网桥内的 OVS 流规则是添加内部 VLAN 标签5
的数据包。查看actions=mod_vlan_vid:5
条目:Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
第二条规则管理到达 int-br-ex (in_port=15)且无 VLAN 标签(vlan_tci=0x0000)的数据包:此规则将 VLAN 标签 5 添加到数据包(
actions=mod_vlan_vid:5,NORMAL
),并将它转发到qvoxxx
。 -
在剥离 VLAN 标签后,
qvoxxx
接受数据包并将其转发到qvbxx
。 - 然后,数据包到达实例。
VLAN 标签 5 是一个 VLAN 示例,用于在具有扁平提供商网络的测试 Compute 节点上使用;这个值由 neutron-openvswitch-agent
自动分配。对于您自己的扁平提供商网络,这个值可能会有所不同,且在两个单独的 Compute 节点上同一网络可能会有所不同。