多网卡bonding
将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。直接给两块网卡设置同一IP 地址是不可以的。通过 bonding,虚拟一块网卡对外提供连接,物理网卡的被修改为相同的MAC地址
Bonding 聚合链路工作模式
bond聚合链路模式共7种模式:0-6 Mode
mod=0 (balance-rr) Round-robin policy(轮询)
聚合口数据报文按包轮询从物理接口转 发。 负载均衡:所有链路处于负载均衡状态
mod=1 (active-backup) Active-backup policy(主-备份策略)
只有Active状态的物理接口 才转发数据报文。 容错能力:只有一个slave是激活的(active)。也就是说同一时刻只有一个网卡处于工作状态,其他 的slave都处于备份状态
mod=2 XOR policy(平衡策略)聚合口数据报文按源目MAC、源目IP、源目 端口进行异或HASH运算得到一个值,根据该值查找接口转发数据报文
负载均衡:基于指定的传输HASH策略传输数据包。容错能力:这模式的特点增加了带宽,同时支持容错能力,当有链路出问题,会把流量切换到正常的链路上
mod=3 broadcast(广播策略)这种模式的特点是一个报文会复制两份往bond下的两个接 口分别发送出去。
当有对端交换机失效,感觉不到任何downtime,但此法过于浪费资源;不过这种模式有很好的容 错机制。此模式适用于金融行 业,因为他们需要高可靠性的网络,不允许出现任何问题。
mod=4, IEEE 802.3ad Dynamic link aggregation(IEEE 802.3ad 动态链接聚合)
聚合组内的成员端口上均启用LACP(链路汇聚控制协议)协议,其端口状态通 过该协议自动进行维护。
mod=5, Adaptive transmit load balancing(适配器传输负载均衡)
在每个物理接口上根据当前的负载(根据速度计算)分配外出流量。如果正在接收数据的物理接口 出故障了,另一个物理接口接管该故障物理口的MAC地址。需要ethtool支持获取每个slave的速率
mod=6, Adaptive load balancing(适配器适应性负载均衡)
该模式包含了balance-tlb模式,同时加上针对IPV4流量的接收负载均衡,而且不需要任何 switch(交换机)的支持。接收负载均衡是通过ARP协商实现的
常用的模式为 0,1,3,6
mode 1、5、6 不需要交换机设置
mode 0、2、3、4需要交换机设置,而且不同类型的交换机设置的时候会有不一样,如Cisco交换机需要在
0,2,3模式中使用 EtherChannel,在4模式中需要使用 LACP和EtherChannel
bonding的实现
修改配置文件实现
[root@rocky86 ~]# cd /etc/sysconfig/network-scripts/
#创建bond配置文件
[root@rocky86 network-scripts]# vim ifcfg-bond0
NAME=bond0
TYPE=bond
DEVICE=bond0
BOOTPROTO=none
IPADDR=192.168.10.100
PREFIX=24
BONDING_OPTS="mode=1 miimon=100 fail_over_mac=1" #工作模式为主备,心跳检测间隔为100ms
#创建网卡配置文件
[root@rocky86 network-scripts]# vim ifcfg-eth1
NAME=eth1
DEVICE=eth1
BOOTPROTO=none
MASTER=bond0
SLAVE=yes
ONBOOT=yes
[root@rocky86 network-scripts]# vim ifcfg-eth2
NAME=eth2
DEVICE=eth2
BOOTPROTO=none
MASTER=bond0
SLAVE=yes
ONBOOT=yes
删除:
[root@rocky86 network-scripts]# nmcli conn down bond0
Connection 'bond0' successfully deactivated (D-Bus active path:
/org/freedesktop/NetworkManager/ActiveConnection/6)
[root@rocky86 network-scripts]# rm -f ifcfg-bond0 ifcfg-eth1 ifcfg-eth2
[root@rocky86 network-scripts]# nmcli conn reload;nmcli conn
在ubuntu中实现bonding
[root@ubuntu ~]# cat /etc/netplan/bond0.yaml
network:
ethernets:
eth1:
addresses: []
dhcp4: false
eth2:
addresses: []
dhcp4: false
version: 2
bonds:
bond0:
addresses: [192.168.10.123/24]
interfaces: [eth1,eth2]
parameters:
mode: balance-rr #bond工作模式,轮询
#生效
[root@ubuntu ~]# netplan apply
#测试,观察两块网卡流量数据
[root@ubuntu ~]# ifconfig -s
#另外一台主机执行 ping 192.168.10.123
```