網卡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
參考連接