将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。直接给两块网卡设置同一IP地址是不可以的。通过 bonding,虚拟一块网卡对外提供连接,物理网卡的被修改为相同的MAC地址。
目录
2.1 mod=0 ,即:(balance-rr) Round-robin policy(平衡轮询环策略)
2.2 mod=1,即: (active-backup) Active-backup policy(主-备份策略)
3.2 mod=2,即:(balance-xor) XOR policy(平衡策略)
3.5 mod=4,即:(802.3ad) IEEE 802.3ad Dynamic link aggregation(IEEE 802.3ad 动态链接聚合)
3.6 mod=5,即:(balance-tlb) Adaptive transmit load balancing(适配器传输负载均衡)
3.7 mod=6,即:(balance-alb) Adaptive load balancing(适配器适应性负载均衡)
聚合口数据报文按包轮询从物理接口转发。即传输数据包顺序是依次传输(即:第1个包走eth0,下一个包就走eth1….一直循环下去,直到最后一个传 输完毕)
负载均衡:所有链路处于负载均衡状态,轮询方式往每条链路发送报文这模式的特点增加了带宽,同时支持容错能力,当有链路出问题,会把流量切换到正常的链路上。
性能问题:一个连接或者会话的数据包如果从不同的接口发出的话,中途再经过不同的链路,在客户端很有可能会出现数据包无序到达的问题,而无序到达的数据包需要重新要求被发送,这样网络的吞吐量就会下降。
Bond0在大压力的网络传输下,性能增长的并不是很理想。
需要交换机进行端口绑定。
这种模式的特点是一个报文会复制两份往bond下的两个接口分别发送出去,当有对端交换机失效,感觉不到任何downtime,但此法过于浪费资源;不过这种模式有很好的容错机制。此模式适用于金融行业,因为他们需要高可靠性的网络,不允许出现任何问题。
在每个物理接口上根据当前的负载(根据速度计算)分配外出流量。如果正在接收数据的物理接口口出故障了,另一个物理接口接管该故障物理口的MAC地址。需要ethtool支持获取每个slave的速率
常用的模式为 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
?bond(绑定)是指将两个或多个物理网卡虚拟化为一个逻辑接口的过程,以实现冗余、负载均衡或增加带宽。
①将网卡的名称改成传统网卡命名方式,修改/etc/default/grub文件修改,添加net.ifname=0
②为grub2生成配置文件
重启reboot
nmcli con add type bond con-name mybond0 ifname bond0 mode active-backup ipv4.method manual ipv4.addresses 192.168.80.100/24
#添加bonding接口
nmcli con add type bond-slave ifname ens33 master bond0
nmcli con add type bond-slave ifname ens36 master bond0
#添加从属接口
#注:如无为从属接口提供连接名,则该名称是接口名称加类型构成
nmcli con up bond-slave-ens33
nmcli con up bond-slave-ens36
#要启动绑定,则必须首先启动从属接口
nmcli con up mybond0
#启动绑定
①添加bonding接口
②添加从属接口
?③启动绑定,首先启动从属接口
④切换到目录下并查看
?
?⑤开启绑定