网卡bonding简介html
网卡绑定就是把多张物理网卡经过软件虚拟成一个虚拟的网卡,配置完毕后,全部的物理网卡的ip和mac将会变成相同的。多网卡同时工做能够提升网络速度,还能够实现网卡的负载均衡、冗余。linux
bonding模式vim
1 round-robin(mode=0)centos
轮转策略,轮流在每个slave网卡上发送数据包,提供负载均衡和容错能力。 bash
2 active-backup(mode=1)服务器
主备策略,只有一个slave被激活,只有当active的slave的接口down时,才会激活其它slave接口。主备模式下发生一次故障切换,在新激活的slave接口上会发送一个或者多个gratuitous ARP。主salve接口上以及配置在接口上的全部VLAN接口都会发送gratuitous ARP,须要在这些接口上配置了至少一个IP地址。VLAN接口上发送的的gratuitous ARP将会附上适当的VLAN id。本模式提供容错能力。网络
Gratuitous ARP也称为免费ARP,无端ARP。Gratuitous ARP不一样于通常的ARP请求,它并不是期待获得ip对应的mac地址,而是当主机启动的时候,将发送一个Gratuitous arp请求,即请求本身的ip地址的mac地址。(来自百度百科:http://baike.baidu.com/view/10101910.htm)
负载均衡
3 XOR(mode=2)ide
基于所选择的hash策略,本模式也提供负载均衡和容错能力。ui
4 broadcast(mode=3)
广播策略,向全部的slave接口发送数据包,本模式提供容错能力。
5 802.3ad(mode=4)
动态链路聚合,根据802.3ad标准利用全部的slave创建聚合链路。slave接口的出口取决于传输的hash策略,默认策略是简单的XOR策略,而hash策略则能够通xmit_hash_policy选项配置。
前提:每一个slave网卡支持ethtool获取速率和双工状态
交换机支持IEEE 802.3ad标准(可能须要配置启用)
IEEE 802.3ad 是执行链路聚合的标准方法。从概念上讲,将多个以太网适配器汇集到单独的虚拟适配器方面与“以太通道(EtherChannel)”的功能相同,能提供更高的带宽防止发生故障。例如,eth0 和 eth1 能够汇集到称做 eth3 的 IEEE 802.3ad链路聚合;而后用 IP 地址配置接口 eth3。系统将这些汇集的适配器做为一个适配器来考虑。所以,能够像在任何以太网适配器上同样配置它们的 IP。(来自百度百科:http://baike.baidu.com/view/1996279.htm?fr=aladdin)
6 balance-tlb(mode=5)
自适应传输负载均衡:根据每一个slave的负载(相对速度)决定从哪一个接口发送数据包,从当前接口接收数据包。若是接收的slave接口故障,其它slave接口将接管它的mac地址继续接收。
前提:每一个slave网卡支持ethtool获取速率。
7 balance-alb(mode=6)
自适应负载均衡:
前提:每一个slave网卡支持ethtool获取速率
每一个slave网卡支持启用时从新设置硬件地址
小结:
mode 一、五、6不须要交换机设置
mode 0、二、三、4须要交换机设置
缺省使用mode 0
bonding驱动加载
cat /boot/config-2.6.32-431.el6.x86_64 | grep -i bonding CONFIG_BONDING=m # 这里能够看出bonding驱动编译成能够动态加载的内核模块 [root@compute1 ~]# vim /etc/modprobe.d/bond.conf # 开机自动加载bonding驱动 alias bond0 bonding options bond0 miimon=100 mode=0 # miimon:多长时间检查一次网络,单位ms;
bonding模式0配置
vim /etc/sysconfig/network-scripts/ifcfg-bond0 # 创建虚拟网卡bond0 DEVICE=bond0 IPADDR=10.10.10.1 NETMASK=255.255.255.0 ONBOOT=yes BOOTPROTO=none USERCTL=no GATEWAY=10.10.10.254
vim /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 BOOTPROTO=none ONBOOT=yes USERCTL=no MASTER=bond0 SLAVE=yes
vim /etc/sysconfig/network-scripts/ifcfg-eth1 DEVICE=eth1 BOOTPROTO=none ONBOOT=yes USERCTL=no MASTER=bond0 SLAVE=yes
# 设置完成后,重启网络服务来使用bond0生效
service network restart # bond模块会自动加载
cat /proc/net/bonding/bond0 # 查看目前bonding的状态 modprobe -r bonding;service network restart # 让bond模式生效
bonding纯网卡配置文件方式
bonding模式1配置
# 具体操做步骤就下面这步不一样,其它一致。 vim /etc/modprobe.d/bond.conf alias bond0 bonding options bond0 miimon=100 mode=1 # 模式1 vim /etc/rc.d/rc.local # eth0 eth1的工做顺序(仅在主备模式下) ifenslave bond0 eth0 eth1
注:在高可用的环境下,网卡配置bonding后,vip_nic要为bond0
bonding模式4配置
# 具体操做步骤就下面这步不一样,其它一致。 vim /etc/modprobe.d/bond.conf alias bond0 bonding options bond0 miimon=100 mode=4 lacp_rate=1 # 模式4
盛科交换机的lacp配置参考:http://pan.baidu.com/s/1o8rL6II 《二层转发保护》
注意的是:交换机和服务器链接的那块要配置动态的channel-group
bond4下启动vlan子接口
# 永久加载8021q module cat > /etc/sysconfig/modules/8021q.modules << EOF \#\!/bin/sh if [ ! `lsmod | grep 8021q` ] ; then exec /sbin/modprobe 8021q >/dev/null 2>&1 fi EOF modprobe 8021q # 加载模块 vim /etc/sysconfig/network-scripts/ifcfg-bond0.110 # vlan子接口,发出去的包是带有vlan tag 110的 DEVICE=bond0.110 # vlan子接口要“.”分隔 BOOTPROTO=none ONBOOT=yes USERCTL=no VLAN=yes # 写配置文件,就不要安装vconfig来配置vlan子接口 IPADDR=192.168.110.3 PREFIX=24
bond4结合OpenStack ovs flat vlan模式
一、 采用linux bridge brctl addbr br-bond brctl addif br-bond bond0 ifconfig br-bond 192.168.1.4/24 # 这样配置是能够通的 二、 采用openvswitch ovs-vsctl add-br br-bond ovs-vsctl add-port br-bond bond0 ifconfig br-bond 192.168.1.4/24 # 这样配置是不通的 若是进行以下操做,网络是能够通的 brctl addbr br-bond brctl addif br-bond bond0 ifconfig br-bond 192.168.1.4/24 # 管理ip地址配置linux bridge上,不是配置在br-data上 ovs-vsctl add-br br-data # 建立一个br-data ovs-vsctl add-port br-data br-bond # br-bond做为ovs bridge的一个port,否则计算节点下的虚拟机网络不通 [root@sha-cloud002 ~]# cat /etc/sysconfig/network-scripts/ifcfg-br-bond # br-data配置文件以下 DEVICE=br-bond IPADDR=10.10.10.12 NETMASK=255.255.255.0 ONBOOT=yes NM_CONTROLLED="no" BOOTPROTO=none TYPE=Bridge DELAY=0 # prevent it waiting on interface start # 这里须要注意一下,若是是hp刀片服务器,网卡作bond后划vlan子接口才能 和上端交换机通讯。这时候配置须要调整下 ovs-vsctl add-port br-data eth0.470(举例vlan id:470) ovs-vsctl set Port eth0.470 tag=470(打了tag后至关于access口,access口出去的包是不带vlan id的)
虽然上述操做也能够,但让人以为怪怪的,下面是OVS下设置lacp的正确方式
按照红帽官网的建议是不要使用基于ovs的lacp,能够考虑使用balance-slb
关于bond模式下网桥配置能够参考红帽的官方文档:https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/6/html/Deployment_Guide/s2-networkscripts-interfaces_network-bridge.html
参考连接