为了提高网络容错或吞吐量,一般服务器都会采取多网卡绑定的策略,在RHEL6中使用的是,而RHEL7提供了一项新的实现技术,具体原理和对比列表大家可以参考扩展阅读中的RedHat官方博客。配置Teaming有两种方式,第一种是使用nmclii命令,第二种是直接修改配置文件。
这里介绍两种最常见的双网卡绑定模式:
(1) roundrobin - 轮询模式
所有链路处于负载均衡状态,这种模式的特点增加了带宽,同时支持容错能力。
(2) activebackup - 主备模式
一个网卡处于活动状态,另一个处于备份状态,所有流量都在主链路上处理,当活动网卡down掉时,启用备份网卡
在RHEL7和Centos7中使用nmtui命令来配置网络,系统默认使用NetworkManager来提供网络服务,这是一种动态管理网络的守护进程,能够让网络设备保持连接状态。可以使用 nmcli 命令来管理 Network Manager 服务。
[root@localhost ~]# nmtui
查看网卡连接信息
[root@localhost ~]# nmcli connection show
NAME UUID TYPE DEVICE
virbr0 b286b35c-cb10-4d7c-980c-af2778929b66 bridge virbr0
查看物理网卡信息
[root@localhost ~]# nmcli dev
设备 类型 状态 CONNECTION
eno16777736 ethernet 已断开 --
eno33554960 ethernet 已断开 --
lo loopback 未管理 --
上面信息可以查看到连接只有virbr0,物理网卡有两个未连接,首先删除无用连接
[root@localhost ~]# nmcli connection delete b91bbba9-5019-48a5-a873-5e1b13df2a7d
建立两个连接
[root@localhost ~]# nmcli connection add type ethernet con-name eno16777736 ifname eno16777736
Connection 'eno16777736' (86cc9bf6-5492-4c41-bfd8-ab89cde271e8) successfully added.
[root@localhost ~]# nmcli connection add type ethernet con-name eno33554960 ifname eno33554960
Connection 'eno33554960' (48db52c1-0449-41c8-9a2b-da3951ea4076) successfully added.
再次查看连接信息
[root@localhost ~]# nmcli connection show
名称 UUID 类型 设备
eno33554960 48db52c1-0449-41c8-9a2b-da3951ea4076 802-3-ethernet eno33554960
eno16777736 86cc9bf6-5492-4c41-bfd8-ab89cde271e8 802-3-ethernet eno16777736
网络连接和配置文件都成功生成,接下来通过eno33554960和eno16777736使用teaming模式进行双网卡绑定
3.1 roundrobin - 轮询模式
roundrobin模式也称为轮询模式,它 基于每一个包 ,当某一台服务器的两张网卡设置为roundrobin模式teaming,此时服务器发出的数据包,就会在两个物理
网卡上进行轮询,即第一个数据包走一张网卡,第二个数据包走第二张网卡,依次轮询。
注意:
(1)roundrobin具有容错性,当一张网卡down掉,数据包依然发送成功。
(2)在使用roundrobin模式必须要在交换机上做以太通道,不然会出现网络无法连通。
使用nmcli命令操作,创建team接口team0,同时设置teaming模式为roundrobin
[root@localhost ~]# nmcli connection add type team con-name team0 ifname team0 config '{"runner":{"name": "roundrobin"}}'
Connection 'team0' (283eb25f-7212-4cc2-a5b5-85d6aa5f2152) successfully added.
给team0设置IP地址,IP模式为手动
[root@localhost ~]# nmcli connection mod team0 ipv4.addresses 192.168.1.20/24 ipv4.gateway 192.168.1.1 ipv4.method manual connectio.autoconnect yes
将两张物理网卡加入到team中
[root@localhost ~]# nmcli connection add type team-slave con-name team0-port1 ifname eno33554960 master team0
Connection 'team0-port1' (96f914fa-f43a-4bc9-8458-10e3923c62f9) successfully added.
[root@localhost ~]# nmcli connection add type team-slave con-name team0-port2 ifname eno16777736 master team0
Connection 'team0-port2' (b1eb81ce-d190-44bb-83a5-deba333fa7b2) successfully added.
重新载入连接配置
[root@192 jun]# nmcli connection reload
启动team0
[root@192 jun]# nmcli connection up team0
成功激活(主服务器等待从服务器)连接(D-Bus 激活路径:/org/freedesktop/NetworkManager/ActiveConnection/8)
查看状态
[root@192 jun]# teamdctl team0 state
setup:
runner: activebackup
runner:
active port:
[root@192 jun]# nmcli connection show
名称 UUID 类型 设备
ens33 f1ce3db1-bea6-44a9-94be-1bc13c1a7a8b 802-3-ethernet ens33
ens38 a2dbd32a-af3f-4c69-82a2-160ae3af95f8 802-3-ethernet ens38
team0 5b68aca4-cd1f-4204-889a-2f7d7467afbc team team0
virbr0 7fbf45c9-eee4-4742-8188-c4c51603f4fa bridge virbr0
team0-port1 027eef4c-52c4-4ce9-a0f0-25acd901beff 802-3-ethernet --
team0-port2 f05ff513-b7de-4729-8b2c-7b886aa22dc6 802-3-ethernet --
[root@192 jun]# nmcli dev
发现发现team0-port1 team0-port2没有添加成功物理网卡
删除掉没有添加成功team0-port1 team0-port2两张网卡
[root@192 jun]# nmcli connection delete team0-port1
成功删除连接 'team0-port1'(7df353c3-b279-4641-9fb9-b9f6276077d1)。
[root@192 jun]# nmcli connection delete team0-port2
成功删除连接 'team0-port2'(0cff2fae-5aa0-4158-8bf4-660ab1445399)。
删除两张物理网卡ens33,ens38
[root@192 jun]# nmcli connection delete ens33 ens38
成功删除连接 'ens38'(a2dbd32a-af3f-4c69-82a2-160ae3af95f8)。
成功删除连接 'ens33'(f1ce3db1-bea6-44a9-94be-1bc13c1a7a8b)。
再次添加team0-port1 team0-port2两张网卡
[root@192 jun]# nmcli connection add type team-slave con-name team0-port1 ifname ens33 master team0
连接“team0-port1”(964b7117-a6e6-4d52-a9bf-d12378aa7eae) 已成功添加。
[root@192 jun]# nmcli connection add type team-slave con-name team0-port2 ifname ens38 master team0
连接“team0-port2”(12794ede-75c1-4737-8a46-69738943f4b2) 已成功添加。
再次查看状态
[root@192 jun]# teamdctl team0 state
setup:
runner: activebackup
ports:
ens33
link watches:
link summary: up
instance[link_watch_0]:
name: ethtool
link: up
down count: 0
ens38
link watches:
link summary: up
instance[link_watch_0]:
name: ethtool
link: up
down count: 0
runner:
active port: ens33
3.2 activebackup-主备模式
一个网卡处于活动状态,另一个处于备份状态,所有流量都在主链路上处理,当活动网卡down掉时,启用备份网卡。
[root@localhost ~]# nmcli connection add type team con-name team0 ifname team0 config '{"runner":{"name": "activebackup"}}'
其余命令一样。
总结:
知道两张物理网卡连接名则:
nmcli connection add type team ifname team0 con-name team0 config '{"runner":{"name":"activebackup"}}'
nmcli connection mod team0 ipv4.addresses 192.168.1.20/24 ipv4.gateway 192.168.1.1
nmcli connection modify team0 ipv4.method manual
nmcli connection add type team-slave con-name team0-port1 ifname ens33 master team0
nmcli connection add type team-slave con-name team0-port2 ifname ens38 master team0
systemctl restart network
teamdctl team0 state