本文重点介绍以下几种常用的虚拟网络接口:
- 虚拟网桥:bridge
- 接口捆绑:bonded和team
- VLAN
- MACVLAN和IPVLAN
- 虚拟路由和转发:vrf
- Overlay与Tunnel:gre、vxlan、geneve
- macvtap、ipvtap
- veth
- dummy
- nlmon
- netdevsim
虚拟网桥 (bridge)
Linux bridge类似于一台网络交换机,把一台机器上的若干个物理或者虚拟的网络接口“连接”起来,负责相连网络接口之间的数据包的二层转发,既可用于和外部路由器或者网关之间收发数据包,也用于转发位于同一台主机上不同虚拟机(VMs)或网络命名空间(network namespace)之间的数据包。Linux bridge支持STP, VLAN filter以及组播侦听(multicast snooping)。
使用下面的ip link
命令,创建如上图所示的虚拟网桥br0
,并将主机的物理接口eth0
、连接虚拟机的tap1
和tap2
、以及网络命名空间的veth1
虚拟接口连接到br0
上。
通常,也可以使用bridge-utils
包中brctl
命令创建和管理虚拟网桥。
接口捆绑:bonded和team
接口捆绑将多个网络接口组合成一个逻辑接口,从而提供冗余和带宽聚合。Linux提供了bonded和team两个driver。
bonding和teaming这两个术语因为都跟接口捆绑或链路聚合有关,它们也经常被混为一谈,但Linux在实现上是有区别的。
使用如下命令,创建一个bonded接口bond1
,将主机上的两个物理接口eth0
和eth1
捆绑成一个逻辑的聚合接口,该聚合接口工作在主备模式,提供了链路的冗余和备份。
teaming可以作为接口聚合的首选方案,因为它提供了比bonding更全面的功能和特性。关于两者在功能特性上的具体区别,可以参考Comparison of network teaming and bonding features。
在下面的命令行中,使用teamd
创建一个team0
聚合接口,并将主机上的eth0
和eth1
加入到这个聚合接口。
VLAN技术
VLAN通过在数据帧上加标签的方式,将一个物理局域网在逻辑上划分成多个广播域,实现广播域的隔离。同一个VLAN内的主机间可以直接通信,而不同VLAN之间不能直接通信,从而将广播报文限制在一个VLAN内。
当需要对虚拟机、容器或者主机进行子网划分时,可以使用VLAN。创建VLAN如下:
以上命令创建了名为eth0.2
的VLAN 2和名为eth0.3
的VLAN 3。拓扑图如下:
MACVLAN和IPVLAN
MACVLAN
使用VLAN,可以在单个接口上创建多个虚拟接口,通过VLAN tag对数据包进行过滤。使用macvlan,可以在单个接口上创建多个虚拟接口,这些虚拟接口都有自己的MAC地址。
在不用macvlan时,如果要把虚拟机或者网络命名空间连接到物理网络,需要创建TAP或者veth设备,并且附加到Linux bridge上,同时,需要把物理接口接到bridge上用来连接到物理网络。但是,使用macvlan之后,网络命名空间就可以直接通过macvlan绑定到物理接口,而无需bridge。如下图所示。
MACVLAN有4种模式,如下图所示。
其中,最常用的是bridge模式。以下命令创建两个bridge模式的macvlan实例,分别分配到两个不同的网络命名空间。
IPVLAN
ipvlan和macvlan非常类似,最大的不同之处在于ipvlan虚拟子接口具有和其父接口相同的mac地址。如下图所示:
ipvlan提供L2和L3两种模式。就功能而言,ipvlan L2模式几乎跟macvlan bridge模式没什么区别,父接口看起来就像一个bridge或者switch。类似地,在IPVLAN 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
-->