【链路聚合】Linux系统配置链路聚合详细步骤

 

前言

链路聚合(英语:Link Aggregation)将多个物理端口汇聚在一起,形成一个逻辑端口,以实现出/入流量吞吐量在各成员端口的负荷分担

网卡的链路聚合就是将多块网卡连接起来,当一块网卡损坏,网络依旧可以正常运行,可以有效的防止因为网卡损坏带来的损失,同时也可以提高网络访问速度。         网卡的链路聚合一般常用的有"bond"和"team"两种模式,"bond"模式最多可以添加两块网卡,"team"模式最多可以添加八块网卡。

 

一、bond

bond的七种模式介绍:

  • 1、mode=0(balance-rr)(平衡抡循环策略)

  • 2、mode=1(active-backup)(主-备份策略)

  • 3、mode=2(balance-xor)(平衡策略)

  • 4、mode=3(broadcast)(广播策略)

  • 5、mode=4(802.3ad)(IEEE 802.3ad 动态链接聚合)

  • 6、mode=5(balance-tlb)(适配器传输负载均衡)

  • 7、mode=6(balance-alb)(适配器适应性负载均衡)

各模式信息,可以查看链接非常详细:

https://blog.51cto.com/linuxnote/1680315

1、查看目前网卡的名称和状态 

 nmcli device status

2、创建bond0口 

nmcli connection add type bond con-name bond0 ifname bond0

3、将接口ens33、ens37加到bond0里去 

nmcli connection add type bond-slave ifname ens33 master bond0 
nmcli connection add type bond-slave ifname ens37 master bond0 

4、静态配置bond0口地址、网关 

nmcli connection modify bond0 ipv4.addresses ‘192.168.10.200/24’ipv4.gateway ‘192.168.10.2’ 

nmcli connection modify bond0 ipv4.method manual 

5、启动 

nmcli connection up bond0 

6、验证 

ip addr show bond0 

ip route

测试断开一块网卡,可以看到切换时会丢失几个包后网络依旧连通着。

 

二、team

1.查看网卡的连接信息

nmcli connnection show

2.创建team,名称为team0

按照下面的语法,用 nmcli 命令为网络组接口创建一个连接。

# nmcli con add type team con-name CNAME ifname INAME [config JSON]

CNAME 指代连接的名称,INAME 是接口名称,JSON (JavaScript Object Notation) 指定所使用的处理器(runner)。JSON语法格式如下:

'{"runner":{"name":"METHOD"}}'

METHOD 是以下的其中一个:broadcast、activebackup、roundrobin、loadbalance 或者 lacp。

最常见的双网卡绑定模式:
            (1) roundrobin - 轮询模式
所有链路处于负载均衡状态,这种模式的特点增加了带宽,同时支持容错能力。
            (2) activebackup - 主备模式
一个网卡处于活动状态,另一个处于备份状态,所有流量都在主链路上处理,当活动网卡down掉时,启用备份网卡。

这里我们创建“”roundrobin“为例”

nmcli con add type team con-name team0 ifname team0 config '{"runner":{"name": "roundrobin"}}'

3.设置team0的ip、gateway、dns

nmcli con modify team0 ipv4.address '192.168.10.188/24' ipv4.gateway '192.168.10.2' 

nmcli con modify team0 ipv4.dns 114.114.114.114

 

4.设置team的属性为manual

nmcli con modify team0 ipv4.method manual

5.添加网卡ens33、ens37到team0中

nmcli con add type team-slave con-name team0-port1 ifname ens33 master team0nmcli con add type team-slave con-name team0-port1 ifname ens37 master team0

6.启动team0

nmcli con up team0

7,查看team0状态

teamdctl team0 state view

通过以上就完成了通过nmcli创建roundrobin的网络team

8,测试是否正常工作

 

 

 

  • 7
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux链路聚合是一种将多个网络接口绑定在一起,形成一个虚拟的高速网络接口的技术。它可以提高网络带宽和可靠性,实现负载均衡和故障转移。在Linux系统中,可以使用bonding驱动程序来实现链路聚合。配置步骤包括:安装bonding驱动程序、创建bonding接口、配置网络接口、设置bonding模式和参数等。常用的bonding模式有:mode 0(负载均衡)、mode 1(主备模式)、mode 4(802.3ad模式)等。配置完成后,可以通过ifconfig或ip命令查看bonding接口的状态和信息。 ### 回答2: 什么是链路聚合链路聚合是一种利用网络传输的多个线路,将它们捆绑在一起形成一个更快,更可靠的高速链路的技术。它也被称为带宽汇聚或网络接口绑定。由于链路聚合将网络传输的多个线路的带宽合并在一起,因此可以提高网络的带宽,同时减少故障单点。 如何在 Linux 上进行链路聚合配置? 在 Linux 系统上,可以通过网络一流的工具 “iproute2” 来实现链路聚合。下面是在 Linux 中配置链路聚合的基本步骤: 1. 安装 iproute2 工具: iproute2 是一套用于 Linux 内核网络层的控制工具,提供了很多网络配置和路由功能。运行以下命令安装: sudo apt-get install iproute2 2. 确认系统支持链路聚合: 运行以下命令确认 您的系统已经安装路由表规则: ip rule show 如果输出信息中没有任何相应规则,则表明你的系统不支持链路聚合。 3. 为链路聚合设置交换机: 链路聚合需要一台交换机来协调多个网络接口的传输。确保您的交换机支持链路聚合,并且已经正确配置。否则在进行网络聚合时,可能会面临网络延迟、故障等问题。 4. 创建聚合群组: 在 Linux 上可以使用bondctl或者ip命令来创建聚合群组。创建聚合群组时可以确定聚合类型(如链接合成、平衡RR等)和聚合模式(如主备、平衡对称、平衡TLB、平衡ALB等)。 下面是一个例子: sudo ip link add bond0 type bond miimon 100 mode 802.3ad 在这个命令中,创建了一个 bond0 接口,类型为 IEEE 802.3ad(即静态链路聚合协议),miimon 设置心跳检查的时间间隔。 Mode 指定链路类型,802.3ad 是一种动态加入的链路聚合协议,可以根据可利用的物理链路的数量动态分配流量,提供了最高的聚合效率。 5. 添加网络接口到聚合群组: 将网络接口添加到刚刚创建的聚合群组中。 命令示例: sudo ip link set enp0s3 master bond0 sudo ip link set enp0s8 master bond0 在这些命令中,我们将 enp0s3 和 enp0s8 接口加入了 bond0 网络聚合群组中。 6. 配置路由表规则: 在 Linux 上,添加多条路由表规则以允许网络接口在规则更改时通畅地切换。例如: ip route add default dev bond0 通过这些命令,我们可以配置 Linux 中的链路聚合。它可以大大提高网络传输的速度,减少系统中的单点故障。 ### 回答3: 链路聚合(Link Aggregation)又称为端口绑定,是将两个或多个物理网卡连接成一个逻辑的、高带宽的、高可靠性的连接的技术。在Linux系统中,链路聚合可以通过bonding模块实现。本文将讨论如何在Linux中配置链路聚合。 1.检查网卡是否支持链路聚合Linux中,可以使用命令“ethtool”来检查网卡是否支持链路聚合。例如,输入“ethtool eth0”就可以查看eth0网卡是否支持链路聚合。 2.安装bonding模块 在安装bonding模块之前,需要安装一些相关的软件包,例如ethtool、lshw等。安装完这些软件包之后,可以使用“modprobe bonding”命令来加载bonding模块。 3.创建bonding接口 通过创建bonding接口,可以将两个或多个物理网卡连接成一个逻辑的、高带宽的、高可靠性的连接。可以使用如下命令创建bonding接口: ifconfig bond0 192.168.0.10 netmask 255.255.255.0 up 其中,bond0是bonding接口的名称,192.168.0.10是IP地址,255.255.255.0是子网掩码。 4.设置bonding模式 在创建bonding接口之后,需要设置bonding模式。Linux中支持七种bonding模式,如下所示: mode=0(balance-rr模式):轮询模式,数据包依次发到不同的网卡上。适用于负载低、带宽要求高的情况。 mode=1(active-backup模式):主备模式,只有其中一个网卡处于工作状态,当主网卡失效时,备网卡会自动接管。适用于稳定性要求高的情况。 mode=2(balance-xor模式):使用异或算法将MAC地址的奇数位和偶数位分别与网卡绑定。适用于环形网络拓扑结构。 mode=3(broadcast模式):所有从bonding接口收到的数据包都会同时发送给所有的物理网卡。适用于小型网络中的广播流量。 mode=4(802.3ad模式):使用IEEE 802.3ad链路聚合控制协议,通过LACP的协商,自适应用指定的方式进行链路聚合。通常用于多台服务器之间的链路聚合。 mode=5(balance-tlb模式):通过流量控制从主网卡导出一部分流量给备网卡,可以实现负载均衡和容错。适用于链路负载较高的情况。 mode=6(balance-alb模式):根据MAC地址进行负载均衡,动态地将MAC地址和网卡绑定在一起。可实现更高的带宽利用率和容错能力。 可以将这些模式中的任意一种设置为bonding的模式。例如,设置为mode=1,可以使用如下命令: echo 1 > /sys/class/net/bond0/bonding/mode 5.添加物理网卡 在创建bonding接口之后,还需要将物理网卡添加到bonding接口中。可以使用如下命令添加eth0和eth1网卡: echo "+eth0" > /sys/class/net/bond0/bonding/slaves echo "+eth1" > /sys/class/net/bond0/bonding/slaves 6.重新启动网络服务 完成以上配置后,需要重新启动网络服务,使用如下命令: systemctl restart network 或者 /etc/init.d/network restart 完成以上步骤后,就可以使用bond0接口来访问网络。这样就能够实现链路聚合,提高网络带宽和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值