百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Linux虚拟网络接口

bigegpt 2024-08-05 11:47 10 浏览

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

  • 虚拟网桥:bridge
  • 接口捆绑:bonded和team
  • VLAN
  • MACVLAN和IPVLAN
  • 虚拟路由和转发:vrf
  • Overlay与Tunnel:gre、vxlan、geneve
  • macvtap、ipvtap
  • veth
  • dummy
  • nlmon
  • netdevsim

虚拟网桥 (bridge)Permalink

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

使用下面的ip link命令,创建如上图所示的虚拟网桥br0,并将主机的物理接口eth0、连接虚拟机的tap1和tap2、以及网络命名空间的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和teamPermalink

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

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

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

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聚合接口,并将主机上的eth0和eth1加入到这个聚合接口。

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技术Permalink

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。拓扑图如下:

MACVLAN和IPVLANPermalink

MACVLANPermalink

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

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

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

IPVLANPermalink

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守护进程向外通告出去。

参考文献Permalink

Introduction to Linux interfaces for virtual networking



相关推荐

Go语言泛型-泛型约束与实践(go1.7泛型)

来源:械说在Go语言中,Go泛型-泛型约束与实践部分主要探讨如何定义和使用泛型约束(Constraints),以及如何在实际开发中利用泛型进行更灵活的编程。以下是详细内容:一、什么是泛型约束?**泛型...

golang总结(golang实战教程)

基础部分Go语言有哪些优势?1简单易学:语法简洁,减少了代码的冗余。高效并发:内置强大的goroutine和channel,使并发编程更加高效且易于管理。内存管理:拥有自动垃圾回收机制,减少内...

Go 官宣:新版 Protobuf API(go pro版本)

原文作者:JoeTsai,DamienNeil和HerbieOng原文链接:https://blog.golang.org/a-new-go-api-for-protocol-buffer...

Golang开发的一些注意事项(一)(golang入门项目)

1.channel关闭后读的问题当channel关闭之后再去读取它,虽然不会引发panic,但会直接得到零值,而且ok的值为false。packagemainimport"...

golang 托盘菜单应用及打开系统默认浏览器

之前看到一个应用,用go语言编写,说是某某程序的windows图形化客户端,体验一下发现只是一个托盘,然后托盘菜单的控制面板功能直接打开本地浏览器访问程序启动的webserver网页完成gui相关功...

golang标准库每日一库之 io/ioutil

一、核心函数概览函数作用描述替代方案(Go1.16+)ioutil.ReadFile(filename)一次性读取整个文件内容(返回[]byte)os.ReadFileioutil.WriteFi...

文件类型更改器——GoLang 中的 CLI 工具

我是如何为一项琐碎的工作任务创建一个简单的工具的,你也可以上周我开始玩GoLang,它是一种由Google制作的类C编译语言,非常轻量和快速,事实上它经常在Techempower的基准测...

Go (Golang) 中的 Channels 简介(golang channel长度和容量)

这篇文章重点介绍Channels(通道)在Go中的工作方式,以及如何在代码中使用它们。在Go中,Channels是一种编程结构,它允许我们在代码的不同部分之间移动数据,通常来自不同的goro...

Golang引入泛型:Go将Interface「」替换为“Any”

现在Go将拥有泛型:Go将Interface{}替换为“Any”,这是一个类型别名:typeany=interface{}这会引入了泛型作好准备,实际上,带有泛型的Go1.18Beta...

一文带你看懂Golang最新特性(golang2.0特性)

作者:腾讯PCG代码委员会经过十余年的迭代,Go语言逐渐成为云计算时代主流的编程语言。下到云计算基础设施,上到微服务,越来越多的流行产品使用Go语言编写。可见其影响力已经非常强大。一、Go语言发展历史...

Go 每日一库之 java 转 go 遇到 Apollo?让 agollo 来平滑迁移

以下文章来源于GoOfficialBlog,作者GoOfficialBlogIntroductionagollo是Apollo的Golang客户端Apollo(阿波罗)是携程框架部门研...

Golang使用grpc详解(golang gcc)

gRPC是Google开源的一种高性能、跨语言的远程过程调用(RPC)框架,它使用ProtocolBuffers作为序列化工具,支持多种编程语言,如C++,Java,Python,Go等。gR...

Etcd服务注册与发现封装实现--golang

服务注册register.gopackageregisterimport("fmt""time"etcd3"github.com/cor...

Golang:将日志以Json格式输出到Kafka

在上一篇文章中我实现了一个支持Debug、Info、Error等多个级别的日志库,并将日志写到了磁盘文件中,代码比较简单,适合练手。有兴趣的可以通过这个链接前往:https://github.com/...

如何从 PHP 过渡到 Golang?(php转golang)

我是PHP开发者,转Go两个月了吧,记录一下使用Golang怎么一步步开发新项目。本着有坑填坑,有错改错的宗旨,从零开始,开始学习。因为我司没有专门的Golang大牛,所以我也只能一步步自己去...