(编辑:jimmy 日期: 2025/1/12 浏览:2)
网卡(接口)绑定是将多块 网卡逻辑地连接到一起从而允许故障转移或者提高吞吐率的方法。提高服务器网络可用性的一个方式是使用多个网卡。Linux 绑定驱动程序提供了一种将多个网卡聚合到一个逻辑的绑定接口的方法。这是个新的实现绑定的方法,并不影响 linux 内核中旧绑定驱动。
网卡绑定为我们提供了两个主要的好处:
现在让我们在 CentOS 7 上配置网卡绑定吧。我们需要决定选取哪些接口配置成一个组接口(Team interface)。
运行 ip link命令查看系统中可用的接口。
$ ip link
这里我们使用 eno16777736和eno33554960网卡在 “主动备份” 模式下创建一个组接口。(译者注:关于不同模式可以参考:多网卡的7种bond模式原理)
按照下面的语法,用 nmcli命令为网络组接口创建一个连接。
# nmcli con add type team con-name CNAME ifname INAME [config JSON]
CNAME指代连接的名称,INAME是接口名称,JSON(JavaScript Object Notation) 指定所使用的处理器(runner)。JSON语法格式如下:
'{"runner":{"name":"METHOD"}}'
METHOD是以下的其中一个:broadcast、activebackup、roundrobin、loadbalance或者lacp。
现在让我们来创建组接口。这是我们创建组接口所使用的命令。
# nmcli con add type team con-name team0 ifname team0 config '{"runner":{"name":"activebackup"}}'
运行 # nmcli con show命令验证组接口配置。
# nmcli con show
现在让我们添加从设备到主设备 team0。这是添加从设备的语法:
# nmcli con add type team-slave con-name CNAME ifname INAME master TEAM
在这里我们添加 eno16777736和eno33554960作为team0接口的从设备。
# nmcli con add type team-slave con-name team0-port1 ifname eno16777736 master team0
# nmcli con add type team-slave con-name team0-port2 ifname eno33554960 master team0
再次用命令 #nmcli con show验证连接配置。现在我们可以看到从设备配置信息。
#nmcli con show
上面的命令会在 /etc/sysconfig/network-scripts/目录下创建需要的配置文件。
现在让我们为 team0 接口分配一个 IP 地址并启用这个连接。这是进行 IP 分配的命令。
# nmcli con mod team0 ipv4.addresses "192.168.1.24/24 192.168.1.1"
# nmcli con mod team0 ipv4.method manual
# nmcli con up team0
用 #ip add show team0命令验证 IP 地址信息。
#ip add show team0
现在用 teamdctl命令检查主动备份配置功能。
# teamdctl team0 state
现在让我们把激活的端口断开连接并再次检查状态来确认主动备份配置是否像希望的那样工作。
# nmcli dev dis eno33554960
断开激活端口后再次用命令 #teamdctl team0 state检查状态。
# teamdctl team0 state
是的,它运行良好!!我们会使用下面的命令连接回到 team0 的断开的连接。
#nmcli dev con eno33554960
我们还有一个 teamnl命令可以显示teamnl命令的一些选项。
用下面的命令检查在 team0 运行的端口。
# teamnl team0 ports
显示 team0当前活动的端口。
# teamnl team0 getoption activeport
好了,我们已经成功地配置了网卡绑定 :-) ,如果有任何反馈,请告诉我们。
作者:Arun Pyasi译者:ictlyh校对:wxy
本文由 LCTT原创翻译,Linux中国荣誉推出
本文由 LCTT 原创翻译,Linux中国首发。也想加入译者行列,为开源做一些自己的贡献么?欢迎加入LCTT!
翻译工作和译文发表仅用于学习和交流目的,翻译工作遵照CC 协议规定,如果我们的工作有侵犯到您的权益,请及时联系我们。
欢迎遵照CC 协议规定转载,敬请在正文中标注并保留原文/译文链接和作者/译者等信息。
文章仅代表作者的知识和看法,如有不同观点,请楼下排队吐槽:D