网卡bonding简介

网卡绑定就是把多张物理网卡通过软件虚拟成一个虚拟的网卡,配置完毕后,所有的物理网卡的ip和mac将会变成相同的。多网卡同时工作可以提高网络速度,还可以实现网卡的负载均衡、冗余。

bonding模式

1    round-robin(mode=0)

轮转策略,轮流在每一个slave网卡上发送数据包,提供负载均衡和容错能力。

2    active-backup(mode=1)

主备策略,只有一个slave被激活,只有当active的slave的接口down时,才会激活其它slave接口。主备模式下发生一次故障切换,在新激活的slave接口上会发送一个或者多个gratuitous ARP。主salve接口上以及配置在接口上的所有VLAN接口都会发送gratuitous ARP,需要在这些接口上配置了至少一个IP地址。VLAN接口上发送的的gratuitous ARP将会附上适当的VLAN id。本模式提供容错能力。

3    XOR(mode=2)

基于所选择的hash策略,本模式也提供负载均衡和容错能力。

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。

6    balance-tlb(mode=5)

自适应传输负载均衡:根据每个slave的负载(相对速度)决定从哪个接口发送数据包,从当前接口接收数据包。如果接收的slave接口故障,其它slave接口将接管它的mac地址继续接收。

前提:每个slave网卡支持ethtool获取速率。

7    balance-alb(mode=6)

自适应负载均衡:

前提:每个slave网卡支持ethtool获取速率

每个slave网卡支持启用时重新设置硬件地址

小结:

  mode 1、5、6不需要交换机设置

  mode 0、2、3、4需要交换机设置

缺省使用mode 0

bonding驱动加载


  1. cat /boot/config-2.6.32-431.el6.x86_64 | grep -i bonding
  2. CONFIG_BONDING=m # 这里可以看出bonding驱动编译成可以动态加载的内核模块
  3. [root@compute1 ~]# vim /etc/modprobe.d/bond.conf # 开机自动加载bonding驱动
  4. alias bond0 bonding
  5. options bond0 miimon=100 mode=0 # miimon:多长时间检查一次网络,单位ms;

bonding模式0配置


  1. vim /etc/sysconfig/network-scripts/ifcfg-bond0 # 建立虚拟网卡bond0 DEVICE=bond0 IPADDR=10.10.10.1
  2. NETMASK=255.255.255.0
  3. ONBOOT=yes
  4. BOOTPROTO=none
  5. USERCTL=no
  6. GATEWAY=10.10.10.254
  7. vim /etc/sysconfig/network-scripts/ifcfg-eth0
  8. DEVICE=eth0
  9. BOOTPROTO=none
  10. ONBOOT=yes
  11. USERCTL=no
  12. MASTER=bond0
  13. SLAVE=yes
  14. vim /etc/sysconfig/network-scripts/ifcfg-eth1
  15. DEVICE=eth1
  16. BOOTPROTO=none
  17. ONBOOT=yes
  18. USERCTL=no
  19. MASTER=bond0
  20. SLAVE=yes # 设置完成后,重启网络服务来使用bond0生效
  21. service network restart # bond模块会自动加载
  22. cat /proc/net/bonding/bond0 # 查看目前bonding的状态
  23. modprobe -r bonding;service network restart # 让bond模式生效

 bonding模式1配置

具体操作步骤就下面这步不同,其它一致。

  1. vim /etc/modprobe.d/bond.conf
  2. alias bond0 bonding
  3. options bond0 miimon=100 mode=1 # 模式1
  4. vim /etc/rc.d/rc.local # eth0 eth1的工作顺序(仅在主备模式下需要做这个设置,其他的模式不需要做这个设置)
  5. ifenslave bond0 eth0 eth1
注:在高可用的环境下,网卡配置bonding后,vip_nic要为bond0

bonding模式4配置


  1. # 具体操作步骤就下面这步不同,其它一致。
  2. vim /etc/modprobe.d/bond.conf
  3. alias bond0 bonding
  4. options bond0 miimon=100 mode=4 lacp_rate=1 # 模式4
注意的是:交换机和服务器连接的那块要配置动态的channel-group (需要配置交换机的动态链路聚合)

bond4下启动vlan子接口

实例:未配置VLAN的mode4的网卡配置文件

  1. # cat ifcfg-eth2
  2. DEVICE=eth2
  3. TYPE=Ethernet
  4. ONBOOT=yes
  5. NM_CONTROLLED=no
  6. BOOTPROTO=static
  7. MASTER=bond0
  8. SLAVE=yes
  9. # cat ifcfg-eth3
  10. DEVICE=eth3
  11. TYPE=Ethernet
  12. ONBOOT=yes
  13. NM_CONTROLLED=no
  14. BOOTPROTO=static
  15. MASTER=bond0
  16. SLAVE=yes
  17. # cat ifcfg-bond0
  18. DEVICE=bond0
  19. TYPE=Ethernet
  20. BOOTPROTO=static
  21. ONBOOT=yes
  22. IPADDR=10.20.42.3
  23. NETMASK=255.255.255.0
  24. GATEWAY=10.20.42.254
  25. # cat /etc/modprobe.d/bonding.conf
  26. alias bond0 bonding
  27. options bond0 miimon=100 mode=4
实例:配置了VLAN-tag的网卡bond文件

  1. [root@sz02 network-scripts]# cat ifcfg-eth0
  2. DEVICE=eth0
  3. IPV6INIT=no
  4. MTU=1500
  5. NM_CONTROLLED=no
  6. ONBOOT=yes
  7. MASTER=bond0
  8. SLAVE=yes
  9. USERCTL=no
  10. BOOTPROTO=none
  11. [root@sz02 network-scripts]# cat ifcfg-eth1
  12. DEVICE=eth1
  13. IPV6INIT=no
  14. MTU=1500
  15. NM_CONTROLLED=no
  16. ONBOOT=yes
  17. MASTER=bond0
  18. SLAVE=yes
  19. USERCTL=no
  20. BOOTPROTO=none
  21. [root@sz02 network-scripts]# cat ifcfg-bond0
  22. DEVICE=bond0
  23. ONBOOT=yes
  24. TYPE=Ethernet
  25. BOOTPROTO=none
  26. BONDING_OPTS='mode=4 miimon=100'
  27. [root@sz02 network-scripts]# cat ifcfg-bond0.101 # 此时的VLAN 的tag就是 101
  28. DEVICE=bond0.101
  29. ONBOOT=yes
  30. TYPE=Ethernet
  31. BOOTPROTO=none
  32. IPADDR=10.101.1.7
  33. NETMASK=255.255.255.0
  34. VLAN=yes
  35. GATEWAY=10.101.1.254
  36. [root@sz02 network-scripts]# cat /etc/modprobe.d/bond.conf # 开机时加载bond模块
  37. alias bond0 bonding
  38. [root@sz02 network-scripts]# lsmod |grep 8021q # 打了VLAN的,机器必需具备8021q模块才可以配通IP
  39. 8021q 20362 0
  40. garp 7152 1 8021q
VLAN是虚拟局域网的缩写。 一个物理交换机上可以共存多个VLAN,这些交换机通过Linux软件配置,而不是通过硬件接口(您仍然需要配置实际的硬件交换机)。

VLAN作为名称建议一次组合多个LAN。 但是,VLAN的优点是什么?

—高性能.

—易于管理.

—安全. 为了安全起见,VLAN为提供了划分LAN的能力。

当将服务器计算机物理移动到另一个位置时,您不必配置任何硬件设备。 关于LAN硬件的注意事项

1.为了能够使用VLAN,需要在以太网上支持IEEE 802.1q标准的交换机。

2.还需要一个与Linux兼容的NIC(网络接口卡),并支持802.1q标准。

  1. # 永久加载8021q module
  2. cat > /etc/sysconfig/modules/8021q.modules << EOF
  3. \#\!/bin/sh
  4. if [ ! `lsmod | grep 8021q` ] ; then
  5. exec /sbin/modprobe 8021q >/dev/null 2>&1
  6. fi
  7. EOF

1

2

3

4

5

6

7

8

9

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模式

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

1、 采用linux bridge

    brctl addbr br-bond

    brctl addif br-bond bond0

    ifconfig br-bond 192.168.1.4/24   # 这样配置是可以通的

    

2、 采用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

详情见:https://access.redhat.com/documentation/en/red-hat-openstack-platform/8/networking-guide/chapter-2-openstack-networking-concepts

关于bond模式下网桥配置可以参考红帽的官方文档:https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/6/html/Deployment_Guide/s2-networkscripts-interfaces_network-bridge.html

</article>

【转帖】网卡bonding模式 - bond0、1、4配置的更多相关文章

  1. 网卡bonding模式 - bond0、1、4配置

    网卡bonding模式 - bond0.1.4配置 网卡bonding简介 网卡绑定就是把多张物理网卡通过软件虚拟成一个虚拟的网卡,配置完毕后,所有的物理网卡的ip和mac将会变成相同的.多网卡同时工 ...

  2. suse 12 双网卡bonding模式

    文章目录 工欲善其事,必先配静态ip 网卡bonding eth0 eth1 192.168.70.52 192.168.70.55 工欲善其事,必先配静态ip 重要的事情说三遍 修改配置之前,先备份 ...

  3. CentOS 7 bonding模式双网卡绑定

    1.1    查看系统内核是否支持bonding [root@cobbler-node1 ~]# cat /boot/config-3.10.0-693.el7.x86_64 | grep -i bo ...

  4. 详解Linux双网卡绑定之bond0

    1.什么是bond? 网卡bond是通过多张网卡绑定为一个逻辑网卡,实现本地网卡的冗余,带宽扩容和负载均衡,在生产场景中是一种常用的技术.Kernels 2.4.12及以后的版本均供bonding模块 ...

  5. Linux下网卡绑定模式

    Linux bonding驱动一共提供了7种模式,它们分别是:balance-rr .active-backup.balance-xor.broadcast.802.3ad.balance-tlb.b ...

  6. linux下网卡bonding配置(转)

    linux下网卡bonding配置   章节 bonding技术 centos7配置bonding centos6配置bonding 一.bonding技术 bonding(绑定)是一种linux系统 ...

  7. Linux下的网卡Bonding

    1. 网卡Bonding一共有0-6七种mode,具体区别请自行搜索: 2. 建议通过nmtui命令在交互模式下配置,这样不会落下重要的字段,也不用去记忆到底有哪些字段: 3. 我的实验环境是VMWa ...

  8. linux下网卡bonding配置

    linux下网卡bonding配置   章节 bonding技术 centos7配置bonding centos6配置bonding 一.bonding技术 bonding(绑定)是一种linux系统 ...

  9. linux网络基础-网卡bonding技术

    1.bondingbonding(绑定)是一种linux系统下的网卡绑定技术,可以把服务器上n个物理网卡在系统内部抽象(绑定)成一个逻辑上的网卡,实现本地网卡的冗余,带宽扩容和负载均衡.在应用部署中是 ...

  10. 为RAC私有网络配置网卡Bonding

    在RAC的安装部署过程中.并不不过简单的安装完毕了事.整个安装过程要考虑可能出现的单点问题,当中比較重要的是私有网络. 私有网络是RAC节点间通信的通道.包含节点间的网络心跳信息.Cache fusi ...

随机推荐

  1. ChatGPT新玩法来了,微信聊天机器人

    前言 上一篇文章中说了ChatGPT是什么,然后怎么注册使用. 传送门:花了1块钱体验一把最近很火的ChatGPT 但是实际操作下来还是有不少小伙伴跟我一样遇到各种坑. 没有魔法工具 OpenAI的服 ...

  2. C#/VB.NET 添加、删除PPT幻灯片中的数字签名

    本文介绍如何通过C#及VB.NET代码来添加数字签名到PPT幻灯片文档,以及如何将文档中的数字签名删除. 辅助工具: Spire.Presentation.dll (dll版本为5.11.2) 注意: ...

  3. JDK1.6在生产环境引起的坑

    本文分享自华为云社区<[高并发]记一次JDK1.6在生产环境引起的坑!>,作者: 冰 河 . 最近有朋友遇到一个困惑:他写的程序在测试环境一点问题没有,但是发到生产环境却会频繁出现内存溢出 ...

  4. 云图说|应用魔方AppCube:揭秘码农防脱神器

    摘要: 应用魔方(AppCube)是华为云为行业客户.合作伙伴.开发者量身打造的一款低代码开发平台.通过AppCube可轻松构建专业级应用,创新随心所欲,敏捷超乎想象. 本文分享自华为云社区<云 ...

  5. 详解CNN实现中文文本分类过程

    摘要:本文主要讲解CNN实现中文文本分类的过程,并与贝叶斯.决策树.逻辑回归.随机森林.KNN.SVM等分类算法进行对比. 本文分享自华为云社区<[Python人工智能] 二十一.Word2Ve ...

  6. CentOS7安装maven,mvn clean -DskipTests package

    1.JAVA_HOME 首先确保正确安装并配置了JAVA_HOME 我这里安装了jdk1.8 2.下载maven 3.6.3 wget https://mirrors.tuna.tsinghua.ed ...

  7. AI Studio 基本操作

    https://aistudio.baidu.com/aistudio/projectdetail/6182202 项目启停 执行和调试 添加代码或文件 运行代码 %cd /home/aistudio ...

  8. 无法访问Docker 里的 mysql, redis

    [root@centos-linux jimmy]# firewall-cmd --state not running [root@centos-linux jimmy]# sysctl net.ip ...

  9. Codeforece : 1360C. Similar Pairs(水题)

    https://codeforces.com/contest/1360/problem/C We call two numbers xx and yy similar if they have the ...

  10. 2021暑假训练赛1 基于Codeforce#479(div3)

    A - Xor Sum 似乎是很明显的字典树问题(不会啊,最后搬了一个板子修修改改以后才过了 AcWing 相似题目:143. 最大异或对 最后得吐槽一下 memset 为什么能这么慢啊 Kora! ...