ubuntu18.04设置链路聚合

多网卡聚合把多个网络端口绑定到一个IP地址,可以提高网络总带宽和容错能力。

网卡绑定的作用

  • 当一个网卡不够用的时候,可以使用两个网卡绑定在一起增加带宽
  • 当一个网卡断的话,另一个网卡可以形成备份,增加链路冗余
  • 主备模式只能做成链路备份,不能负载,负载需要服务器和交换机互相配合

bond 的七种模式。

这边给大家介绍两种,一种是主备模式,一种是和交换机配合的链路聚合。
这七种模式分别是:

第⼀种模式:mod=0,即:(balance-rr) Round-robin policy(平衡抡循环策略)
特点:传输数据包顺序是依次传输(即:第1个包⾛eth0,下⼀个包就⾛eth1….⼀直循环下去,直到最后⼀个传输完
毕),此模式提供负载平衡和容错能⼒。

第⼆种模式:mod=1,即: (active-backup) Active-backup policy(主-备份策略)
特点:只有⼀个设备处于活动状态,当⼀个宕掉另⼀个⻢上由备份转换为主设备。mac地址是外部可⻅得,从外⾯看
来,bond的MAC地址是唯⼀的,以避免switch(交换机)发⽣混乱。此模式只提供了容错能⼒;由此可⻅此算法的优点
是可以提供⾼⽹络连接的可⽤性,但是它的资源利⽤率较低,只有⼀个接⼝处于⼯作状态,在有 N 个⽹络接⼝的情况 下,资源利⽤率为1/N。

第三种模式:mod=2,即:(balance-xor) XOR policy(平衡策略)
特点:基于指定的传输HASH策略传输数据包。缺省的策略是:(源MAC地址 XOR ⽬标MAC地址) % slave数量。其他
的传输策略可以通过xmit_hash_policy选项指定,此模式提供负载平衡和容错能⼒。

第四种模式:mod=3,即:broadcast(⼴播策略) 特点:在每个slave接⼝上传输每个数据包,此模式提供了容错能⼒。

第五种模式:mod=4,即:(802.3ad) IEEE 802.3adDynamic link aggregation(IEEE
802.3ad 动态链接 聚合) 特点:创建⼀个聚合组,它们共享同样的速率和双⼯设定。根据802.3ad规范将多个slave⼯作在同⼀个激活的聚合体 下。 必要条件:
条件1:ethtool⽀持获取每个slave的速率和双⼯设定。 条件2:switch(交换机)⽀持IEEE 802.3ad Dynamic
link aggregation。 条件3:⼤多数switch(交换机)需要经过特定配置才能⽀持802.3ad模式。

第六种模式:mod=5,即:(balance-tlb) Adaptive transmit load
balancing(适配器传输负载均衡)
特点:不需要任何特别的switch(交换机)⽀持的通道bonding。在每个slave上根据当前的负载(根据速度计算)分
配外出流量。如果正在接受数据的slave出故障了,另⼀个slave接管失败的slave的MAC地址。 该模式的必要条件:
ethtool⽀持获取每个slave的速率

第七种模式:mod=6,即:(balance-alb) Adaptive load balancing(适配器适应性负载均衡)
特点:该模式包含了balance-tlb模式,同时加上针对IPV4流量的接收负载均衡(receive load balance,
rlb),⽽且不需要任何switch(交换机)的⽀持。

Ubuntu 18.04使用了netplan来管理网络,跟以前版本差别很大。以前版本修改/etc/network/interfaces的方法不再管用,设置多网卡聚合的

方式也有点不一样了,不过实际用起来比以前还要简单。

系统缺省配置

对于Ubuntu 18.04 Server版,在/etc/netplan下头有一个50-cloud-init.yaml文件,是系统安装时创建的,中间会询问是否启用网卡端口聚合,

如果回答是,就会生成相应的配置参数。文件位于 /etc/netplan/00-cloud-init.yaml。

内容如下:

# This file is generated from information provided by
# the datasource. Changes to it will not persist across an instance.
# To disablecloud-init's network configuration capabilities, write a file
# /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg with the following:
# network: {config: disabled}
version: 2
network:
  ethernets:
    enp3s0f0:
      addresses: []
      dhcp4: true
      dhcp6: true
    enp3s0f1:
      addresses: []
      dhcp4: true
      dhcp6: true
  bonds:
    bond0:
      addresses: []
      interfaces:
      - enp3s0f0
      - enp3s0f1
      parameters:
        lacp-rate: fast
        mode: 802.3ad
        transmit-hash-policy: layer2

如果前期没有选择,只能后期手工修改配置文件。目前网络配置面板里看不到聚合端口,不能用来维护这个配置参数。

手工创建这个文件:

  • 注意:
    • 在Ubuntu 18.04桌面版没有这个文件,但是可以用同样的方法配置。
    • 在运行netplan apply命令时,/etc/netplan下所有的*.yaml配置文件都会被启用。

缺省情况下,配置参数在重启机器时会自动生效。如果需要立即启用,可以运行:sudo netplan apply。

在此运行 ifconfig,会多出来一个bond0的虚拟网卡,这是我们上面设置的聚合IP地址。

更新配置的版本

将聚合网址设为静态IP地址。

1、首先,备份原来的配置文件。

 sudo mv /etc/netplan/00-cloud-init.yaml /etc/netplan/00-cloud-init.old

2、创建一个新的配置文件,可以使用任何文件名称,扩展名必须为.yaml

 sudo touch /etc/netplan/my-netowork-file.yaml

3、编辑其内容:

sudo vim /etc/netplan/my-network-file.yaml

添加静态IP地址设置的内容:

  • 查看网卡名称:ifconfig -a或者ip address

把下面的地址设为自己子网内可用的空余IP地址,注意不要与其它网址冲突。

完整的配置文件为:

# this is the network config written bu `subiquity`
network:
  ethernets:
    enp4s0f0: {}
    enp4s0f1: {}
  renderer: networkd
  bonds:
    bond0:
      addresses: [192.168.xx.xx/xx]
      gateway4: 192.168.xx.xx
      nameservers:
        addresses:[114.114.114.114,202.96.128.86]
      interfaces:
        - enp4s0f0
        - enp4s0f1
      parameters:
        mode: 802.3ad   #模式
        mii-monitor-interval:
        lacp-rate: fast
        transmit-hash-policy: layer2

4、启用新配置。

然后,运行:

sudo netplan apply

可以立即生效,或者重启一下。你取消了bond模式之后也要重启才能生效。

注意:不要用tab键来补全,只能按空格键

检查一下:

# ip address
1: lo:  mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: enp5s0:  mtu 1500 qdisc fq_codel master bond0 state UP group default qlen 1000
    link/ether a2:ee:41:9d:58:82 brd ff:ff:ff:ff:ff:ff
3: enp6s0:  mtu 1500 qdisc fq_codel master bond0 state UP group default qlen 1000
    link/ether a2:ee:41:9d:58:82 brd ff:ff:ff:ff:ff:ff
4: enp4s0f0:  mtu 1500 qdisc fq_codel master bond0 state UP group default qlen 1000
    link/ether a2:ee:41:9d:58:82 brd ff:ff:ff:ff:ff:ff
5: enp4s0f1:  mtu 1500 qdisc fq_codel master bond0 state UP group default qlen 1000
6: bond0:  mtu 1500 qdisc noqueue state UP group default qlen 1000
    link/ether a2:ee:41:9d:58:82 brd ff:ff:ff:ff:ff:ff
    inet 192.168.xx.xx/xx brd 192.168.19.255 scope global bond0
       valid_lft forever preferred_lft forever
    inet6 fe80::a0ee:41ff:fe9d:5882/64 scope link 
       valid_lft forever preferred_lft forever

或者:

//查看bond0工作状态信息
root@ubuntu~# cat /proc/net/bonding/bond0 

网卡端口聚合还可以用于多路宽带上网,速度翻倍。

 

 

你可能感兴趣的:(网口聚合,linux,ubuntu,负载均衡)