本文重点介绍以下几种常用的虚拟网络接口:

虚拟网桥 (bridge)

Linux bridge类似于一台网络交换机,把一台机器上的若干个物理或者虚拟的网络接口“连接”起来,负责相连网络接口之间的数据包的二层转发,既可用于和外部路由器或者网关之间收发数据包,也用于转发位于同一台主机上不同虚拟机(VMs)或网络命名空间(network namespace)之间的数据包。Linux bridge支持STP, VLAN filter以及组播侦听(multicast snooping)。

Linux虚拟网桥

使用下面的ip link命令,创建如上图所示的虚拟网桥br0,并将主机的物理接口eth0、连接虚拟机的tap1tap2、以及网络命名空间的veth1虚拟接口连接到br0上。

ip link add br0 type bridge
ip link set eth0 master br0
ip link set tap1 master br0
ip link set tap2 master br0
ip link set veth1 master br0

通常,也可以使用bridge-utils包中brctl命令创建和管理虚拟网桥。

接口捆绑:bonded和team

接口捆绑将多个网络接口组合成一个逻辑接口,从而提供冗余和带宽聚合。Linux提供了bonded和team两个driver。

接口捆绑

bonding和teaming这两个术语因为都跟接口捆绑或链路聚合有关,它们也经常被混为一谈,但Linux在实现上是有区别的。

使用如下命令,创建一个bonded接口bond1,将主机上的两个物理接口eth0eth1捆绑成一个逻辑的聚合接口,该聚合接口工作在主备模式,提供了链路的冗余和备份。

ip link add bond1 type bond miimon 100 mode active-backup
ip link set eth0 master bond1
ip link set eth1 master bond1

teaming可以作为接口聚合的首选方案,因为它提供了比bonding更全面的功能和特性。关于两者在功能特性上的具体区别,可以参考Comparison of network teaming and bonding features

在下面的命令行中,使用teamd创建一个team0聚合接口,并将主机上的eth0eth1加入到这个聚合接口。

teamd -o -n -U -d -t team0 -c '{"runner": {"name": "loadbalance"},"link_watch": {"name": "ethtool"}}'
ip link set eth0 down
ip link set eth1 down
teamdctl team0 port add eth0
teamdctl team0 port add eth1

VLAN技术

VLAN通过在数据帧上加标签的方式,将一个物理局域网在逻辑上划分成多个广播域,实现广播域的隔离。同一个VLAN内的主机间可以直接通信,而不同VLAN之间不能直接通信,从而将广播报文限制在一个VLAN内。

数据帧的VLAN封装格式

当需要对虚拟机、容器或者主机进行子网划分时,可以使用VLAN。创建VLAN如下:

vconfig add eth0 2
ip link set eth0.2 up
vconfig add eth0 3
ip link set eth0.3 up

以上命令创建了名为eth0.2的VLAN 2和名为eth0.3的VLAN 3。拓扑图如下:

vlan虚拟接口

MACVLAN和IPVLAN

MACVLAN

使用VLAN,可以在单个接口上创建多个虚拟接口,通过VLAN tag对数据包进行过滤。使用macvlan,可以在单个接口上创建多个虚拟接口,这些虚拟接口都有自己的MAC地址。

在不用macvlan时,如果要把虚拟机或者网络命名空间连接到物理网络,需要创建TAP或者veth设备,并且附加到Linux bridge上,同时,需要把物理接口接到bridge上用来连接到物理网络。但是,使用macvlan之后,网络命名空间就可以直接通过macvlan绑定到物理接口,而无需bridge。如下图所示。

macvlan

MACVLAN有4种模式,如下图所示。

macvlan的4种模式

其中,最常用的是bridge模式。以下命令创建两个bridge模式的macvlan实例,分别分配到两个不同的网络命名空间。

ip link add macv1 link eth0 type macvlan mode bridge
ip link add macv2 link eth0 type macvlan mode bridge
ip netns add net1
ip netns add net2
ip link set macv1 netns net1
ip link set macv2 netns net2

IPVLAN

ipvlan和macvlan非常类似,最大的不同之处在于ipvlan虚拟子接口具有和其父接口相同的mac地址。如下图所示:

ipvlan

ipvlan提供L2和L3两种模式。就功能而言,ipvlan L2模式几乎跟macvlan bridge模式没什么区别,父接口看起来就像一个bridge或者switch。类似地,在IPVLAN L3模式下,父接口就像一台路由器,端点之间的数据包通过它进行路由,这种模式具有更好的扩展性。

ipvlan的L2和L3模式

使用如下命令,在父接口eth0上创建两个ipvlan虚拟设备,并分别添加到两个不同的网络命名空间。

ip link add ipv1 link eth0 type ipvlan mode l2
ip link add ipv2 link eth0 type ipvlan mode l2
ip netns add net1
ip netns add net2
ip link set dev ipv1 netns net1
ip link set dev ipv2 netns net2

macvlan和ipvlan不能同时用在同一个父接口下面。既然macvlan和ipvlan在很多方面都类似,那么什么时候用ipvlan,什么时候用macvlan呢?在ipvlan内核文档中指出,在下列几种情况下应考虑选择ipvlan:

  • 主机所连接的外部交换机或路由器配置了规则:每个端口只允许一个mac地址连接(mac地址绑定)。
  • 在主设备上创建的虚拟设备数量超过了mac地址容量,网卡配置混杂模式之后,会损失性能。
  • 你需要一个更加高级的网络场景,例如你需要把在VM或容器中运行的服务利用BGP守护进程向外通告出去。

参考文献

Introduction to Linux interfaces for virtual networking


-->