Linux实现多网卡聚合绑定bonding

Posted 白-胖-子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux实现多网卡聚合绑定bonding相关的知识,希望对你有一定的参考价值。

多网卡聚合bonding

  • 生产环境通常需要将多块网卡绑定同一IP地址对外提供服务,以实现高可用或者负载均衡。
  • 直接给两块网卡设置同一IP地址是不可以的。
  • 通过 bonding技术,将多块物理网卡虚拟成一块网卡对外提供连接,
  • bonding后多块物理网卡MAC地址被修改为相同的以接受报文

Bonding 聚合链路工作模式

bond聚合链路模式共7种模式:0-6 Mode

mod=0 balance-rr

  • Round-robin policy(轮询)聚合口数据报文按包轮询从物理接口转发。

mod=1 active-backup

  • Active-backup policy(主-备份策略)只有Active状态的物理接口才转发数据报文。

mod=2 balance-xor

  • XOR policy(平衡策略)聚合口数据报文按源目MAC、源目IP、源目端口进行异或HASH运算得到一个值,
  • 根据该值查找接口转发数据报文负载均衡—基于指定的传输HASH策略传输数据包。

mod=3 broadcast

  • broadcast(广播策略)这种模式的特点是一个报文会复制两份往bond下的两个接口分别发送出去,

mod=4 802.3ad

  • IEEE 802.3ad Dynamic link aggregation(IEEE 802.3ad 动态链接聚
    合)
  • 在动态聚合模式下,聚合组内的成员端口上均启用LACP(链路汇聚控制协议)协议,其端口状态通过该协议自动进行维护。

mod=5 balance-tlb

  • Adaptive transmit load balancing(适配器传输负载均衡)
  • 在每个物理接口上根据当前的负载(根据速度计算)分配外出流量。
  • 如果正在接收数据的物理接口口出故障了,另一个物理接口接管该故障物理口的MAC地址。
  • 需要ethtool支持获取每个slave的速率

mod=6 balance-alb

  • Adaptive load balancing(适配器适应性负载均衡)
  • 该模式包含了balance-tlb模式,同时加上针对IPV4流量的接收负载均衡,而且不需要任何switch(交换机)的支持。
  • 接收负载均衡是通过ARP协商实现的。
  • bonding驱动截获本机发送的ARP应答,并把源硬件地址改写为bond中某个物理接口的唯一硬件地址,从而使得不同的对端使用不同的硬件地址进行通信。

mod=6与mod=0的区别

  • mod=6,先把eth0流量占满,再占eth1,….ethX;
  • 而mod=0的话,会发现2个口的流量都很稳定,基本一样的带宽。而mod=6,会发现第一个口流量很高,第2个口只占了小部分流量

常用bonding模式

常用模式为 0,1,3,6

  • mode 1、5、6 不需要交换机设置
  • mode 0、2、3、4需要交换机设置
  • active-backup、balance-tlb 和 balance-alb 模式不需要交换机的任何特殊配置。
  • 其他绑定模式需要配置交换机以便整合链接。
  • 如:Cisco 交换机需要在模式 0、2 和 3 中使用 EtherChannel,但在模式4中需要 LACP和 EtherChannel

Linux网卡Bonding 配置

创建bonding设备配置文件

  • 将本机IP配置在bond0这块虚拟网卡上
  • miimon指定链路监测时间间隔。
  • 如果miimon=100,那么系统每100ms 监测一次链路连接状态,
  • 如果有一条线路不通就转入另一条线路
cat > /etc/sysconfig/network-scripts/ifcfg-bond0 <<SUN
NAME=bond0
TYPE=bond
DEVICE=bond0
BOOTPROTO=none
IPADDR=10.0.0.100
PREFIX=8
BONDING_OPTS="mode=1 miimon=100 fail_over_mac=1"
SUN

配置本地物理网卡设备配置文件

  • 将本地物理网卡绑定到虚拟网卡上
  • 覆盖配置前记得备份源文件
cat >/etc/sysconfig/network-scripts/ifcfg-eth0 <<SUN
NAME=eth0
DEVICE=eth0
BOOTPROTO=none
MASTER=bond0
SLAVE=yes
ONBOOT=yes
SUN

cat >/etc/sysconfig/network-scripts/ifcfg-eth1 <<SUN
NAME=eth1
DEVICE=eth1
BOOTPROTO=none
MASTER=bond0
SLAVE=yes
ONBOOT=yes
SUN

重启网络服务

systemctl restrat network.service

查看bond0状态

/proc/net/bonding/bond0

删除bond0

  • 删除绑定后需要恢复本地网卡IP配置才能访问
    ifconfig bond0 down
    rmmod bonding

以上是关于Linux实现多网卡聚合绑定bonding的主要内容,如果未能解决你的问题,请参考以下文章

Linux多网卡绑定聚合链路—bond技术

linux多网卡绑定聚合——bond技术

linux多网卡绑定聚合-Bond详细完整版

Linux平台双网卡绑定技术实现负载均衡(网卡聚合)bonding

linux 单网卡绑定多IP及BONGDING的实现

Linux 链路聚合