热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linux网卡绑定的七种工作模式详解

本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。

Linux 网卡绑定的七种工作模式详解

什么是网卡绑定(Bonding)?

网卡绑定是通过将多张物理网卡组合成一个逻辑网卡,以实现网络冗余、带宽扩展和负载均衡的技术。该技术在生产环境中广泛应用,特别是在需要高可靠性和高性能的网络环境中。

自Linux内核版本2.4.12起,bonding模块成为标准组件。对于更早的内核版本,可以通过补丁来实现相同功能。可以使用以下命令检查当前内核是否支持bonding:

# cat /boot/config-2.6.32-573.el6.x86_64 | grep -i bonding
CONFIG_BOnDING=m

七种工作模式介绍

1. mode=0 (balance-rr):循环平衡模式

此模式通过轮询方式分配数据包,增加带宽并提供容错能力。交换机需配置端口聚合(如Cisco的port channel)。每个数据包依次从不同的网卡发送,直到所有网卡轮流发送完毕。

  • 特点:提供负载均衡和故障切换;但可能导致客户端接收无序数据包,影响吞吐量。
  • 优点:带宽翻倍。
  • 缺点:需要交换机支持端口聚合。

2. mode=1 (active-backup):主备模式

在此模式下,仅有一块网卡处于活动状态,另一块作为备用。当主网卡失效时,备用网卡立即接管流量。此模式不支持交换机端口聚合。

  • 特点:仅有一个网卡工作,提供高冗余性;MAC地址唯一,避免交换机混乱。
  • 优点:高可靠性。
  • 缺点:资源利用率低,只有单个网卡工作。

3. mode=2 (balance-xor):XOR哈希模式

基于指定的传输哈希策略(默认为源MAC地址 XOR 目标MAC地址 % 网卡数量)选择网卡发送数据包。需要交换机支持端口聚合。

  • 特点:提供负载均衡和容错能力。

4. mode=3 (broadcast):广播模式

所有数据包从所有网卡发送,提供高冗余性但浪费资源。适用于金融等对网络可靠性要求极高的行业。

  • 特点:每个网卡发送相同的数据包,提供容错能力。
  • 必要条件:ethtool支持获取速率和双工设定;交换机支持IEEE 802.3ad动态链路聚合。

5. mode=4 (802.3ad):IEEE 802.3ad 动态链路聚合

遵循802.3ad标准,通过LACP协议与交换机配合,创建聚合组共享相同的速率和双工设置。外出流量根据传输哈希策略选择网卡。

  • 特点:创建聚合组,提供负载均衡和容错能力;需要注意包乱序问题。
  • 必要条件:ethtool支持获取速率和双工设定;交换机支持IEEE 802.3ad。

6. mode=5 (balance-tlb):适配器传输负载均衡

根据每个网卡的负载情况动态分配外出流量,接收流量使用当前轮到的网卡。无需交换机特殊支持。

  • 特点:不需要交换机支持;根据网卡负载分配流量;故障切换时接管MAC地址。
  • 必要条件:ethtool支持获取速率。

7. mode=6 (balance-alb):适配器自适应负载均衡

在mode=5基础上增加了接收负载均衡(RLB),无需交换机支持。通过ARP协商实现接收流量的负载均衡。

  • 特点:包含balance-tlb模式,同时实现接收负载均衡;通过ARP协商管理流量分布。
  • 必要条件:ethtool支持获取速率;驱动支持设置硬件地址。

小结

mode=5和mode=6无需交换机端配置,网卡能自动聚合。mode=4需要支持802.3ad。mode=0、mode=2和mode=3理论上需要静态聚合方式。

二、配置实例

首先确认Linux是否支持bonding:

# modinfo bonding | more
filename: /lib/modules/2.6.32-431.el6.x86_64/kernel/drivers/net/bonding/bonding.ko
author: Thomas Davis, tadavis@lbl.gov and many others
description: Ethernet Channel Bonding Driver, v3.6.0
version: 3.6.0
license: GPL
srcversion: 353B1DC123506708446C57B
depends: 8021q,ipv6
vermagic: 2.6.32-431.el6.x86_64 SMP mod_unload modversions

如显示上述信息,则说明支持bonding。

配置文件示例:

[root@jacken ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE=eth0
HWADDR=EC:F4:BB:DC:4C:0C
TYPE=Ethernet
UUID=669f0694-9c52-4792-bd67-22c9d2c17acb
OnBOOT=yes
NM_COnTROLLED=no
BOOTPROTO=none
MASTER=bond0
SLAVE=yes
[root@jacken ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth1
DEVICE=eth1
HWADDR=EC:F4:BB:DC:4C:0D
TYPE=Ethernet
UUID=1d2f30f4-b3f0-41a6-8c37-54f03115f7bd
OnBOOT=yes
NM_COnTROLLED=no
BOOTPROTO=none
MASTER=bond0
SLAVE=yes
[root@jacken ~]# cat /etc/sysconfig/network-scripts/ifcfg-bond0
DEVICE=bond0
NAME='System bond0'
TYPE=Ethernet
NM_COnTROLLED=no
USERCTL=no
OnBOOT=yes
BOOTPROTO=none
IPADDR=192.168.1.100
NETMASK=255.255.255.0
BONDING_OPTS='mode=1 miimon=100'
IPV6INIT=no

开机自动加载模块:

# echo 'options bonding mode=0 miimon=200' >> /etc/modprobe.d/dist.conf
# echo 'ifenslave bond0 eth0 eth1' >> /etc/rc.local
miimon=100

每100毫秒监测一次连接状态,若线路不通则切换至另一条线路。

查看bond0状态:

# cat /proc/net/bonding/bond0
[root@compute05 ~]# cat /proc/net/bonding/bond0
Ethernet Channel Bonding Driver: v3.7.1 (April 27, 2011)
Bonding Mode: fault-tolerance (active-backup)
Primary Slave: None
Currently Active Slave: eth1
MII Status: up
MII Polling Interval (ms): 100
Up Delay (ms): 0
Down Delay (ms): 0
Slave Interface: eth0
MII Status: up
Speed: 1000 Mbps
Duplex: full
Link Failure Count: 0
Permanent HW addr: ec:f4:bb:dc:4c:0c
Slave queue ID: 0
Slave Interface: eth1
MII Status: up
Speed: 1000 Mbps
Duplex: full
Link Failure Count: 0
Permanent HW addr: ec:f4:bb:dc:4c:0d
Slave queue ID: 0

三、扩展配置

如果要配置多个bond接口(如eth0和eth1组成bond0,eth2和eth3组成bond1),可以通过以下两种方法:

1. 第一种方法:

alias bond0 bonding
alias bond1 bonding
options bonding max_bOnds=2 miimon=200 mode=1

2. 第二种方法:

alias bond0 bonding
options bond0 miimon=100 mode=1
install bond1 /sbin/modprobe bonding -o bond1 miimon=100 mode=0
install bond2 /sbin/modprobe bonding -o bond2 miimon=100 mode=1
install bond3 /sbin/modprobe bonding -o bond3 miimon=100 mode=0

不同bond接口可以设定不同模式,注意启动脚本的配置:

ifenslave bond0 eth0 eth1
ifenslave bond1 eth2 eth3
ifenslave bond2 eth4 eth5
ifenslave bond3 eth6 eth7

推荐阅读
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 在尝试使用C# Windows Forms客户端通过SignalR连接到ASP.NET服务器时,遇到了内部服务器错误(500)。本文将详细探讨问题的原因及解决方案。 ... [详细]
  • 本文详细介绍了如何在云服务器上配置Nginx、Tomcat、JDK和MySQL。涵盖从下载、安装到配置的完整步骤,帮助读者快速搭建Java Web开发环境。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 本文介绍如何使用布局文件在Android应用中排列多行TextView和Button,使其占据屏幕的特定比例,并提供示例代码以帮助理解和实现。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
  • 优化SQL Server批量数据插入存储过程的实现
    本文介绍了一种改进的SQL Server存储过程,用于生成批量插入语句。该方法不仅提高了性能,还支持单行和多行模式,适用于SQL Server 2005及以上版本。 ... [详细]
author-avatar
娅丶0k_732
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有