热门标签 | 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

推荐阅读
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 解读MySQL查询执行计划的详细指南
    本文旨在帮助开发者和数据库管理员深入了解如何解读MySQL查询执行计划。通过详细的解析,您将掌握优化查询性能的关键技巧,了解各种访问类型和额外信息的含义。 ... [详细]
  • 本文详细介绍如何使用Samba软件配置CIFS文件共享服务,涵盖安装、配置、权限管理及多用户挂载等关键步骤。通过具体示例和命令行操作,帮助读者快速搭建并优化Samba服务器。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • PostgreSQL 10 离线安装指南
    本文详细介绍了如何在无法联网的服务器上进行 PostgreSQL 10 的离线安装,并涵盖了从下载安装包到配置远程访问的完整步骤。 ... [详细]
  • 本文探讨了在 ASP.NET MVC 5 中实现松耦合组件的方法。通过分离关注点,应用程序的各个组件可以更加独立且易于维护和测试。文中详细介绍了依赖项注入(DI)及其在实现松耦合中的作用。 ... [详细]
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社区 版权所有