网络技术基础(17)——以太网链路聚合

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
简介: 【3月更文挑战第4天】网络基础笔记(加班了几天,中途耽搁了,预计推迟6天)

网络可靠性是什么?

网络的可靠性指当设备或者链路出现单点或者多点故障时保证网络服务不间断的能力。

实际工作中网络需要保证可靠性,实现冗余设计。会从三个层次实现:

  • 链路冗余

  • 单板冗余

  • 整机设备冗余

网络的可靠性指当设备或者链路出现单点或者多点故障时保证网络服务不间断的能力。

image.png

这次我们主要学习链路可靠性,通过一些技术实现多条网线共同工作,当其中一条断开不影响网络业务。

image.png

为保证设备间链路可靠性,在设备间部署多条物理线路,为防止环路STP只保留一条链路转发流量,其余链路成为备份链路。

以太网链路聚合原理

概述

设备之间存在多条链路时,由于STP的存在,实际只会有一条链路转发流量,设备间链路带宽无法得到提升。STP知识参考之前的文章。

image.png

以太网链路聚合Eth-Trunk:简称链路聚合,通过将多个物理接口捆绑成为一个逻辑接口,可以在不进行硬件升级的条件下,达到增加链路带宽的目的。简单讲就是提高链路利用率,让多条链路逻辑上成为一个端口,这样STP就将这个逻辑接口当成一个端口而不会进行阻塞。

image.png

工作原理

image.png

聚合组(Link Aggregation Group,LAG)::若干条链路捆绑在一起所形成的的逻辑链路。每个聚合组唯一对应着一个逻辑接口,这个逻辑接口又被称为链路聚合接口或Eth-Trunk接口。

成员接口和成员链路:组成Eth-Trunk接口的各个物理接口称为成员接口。成员接口对应的链路称为成员链路。

活动接口和活动链路:活动接口又叫选中(Selected)接口,是参与数据转发的成员接口。活动接口对应的链路被称为活动链路(Active link)

非活动接口和非活动链路:又叫非选中(Unselected)接口,是不参与转发数据的成员接口。非活动接口对应的链路被称为非活动链路(Inactive link)。

聚合模式 :根据是否开启LACP(Link Aggregation Control Protocol,链路聚合控制协议),链路聚合可以分为手工模式和LACP模式。

【注意事项】

1、链路聚合接口可以作为普通的以太网接口来使用,与普通以太网接口的差别在于:转发的时候链路聚合组需要从成员接口中选择一个或多个接口来进行数据转发。也就是可以配置Trunk口与Access口等。

2、一个聚合组内要求成员接口以下参数相同:

  • 接口速率

  • 双工模式

  • VLAN配置

大白话讲就是,创建一个聚合逻辑组,然后将多个物理接口加入到聚合组,然后可以设置其中的活动接口和备份接口,比如4个接口只保留3个活动接口,接口对应就是那条链路,然后聚合组和普通的二层接口一致可以配置Trunk和Access等,两端设备建议保持一致。

链路聚合的两种工作模式

链路聚合有两种模式:手工模式,LACP模式。

手工模式

image.png

手工模式: Eth-Trunk的建立、成员接口的加入均由手动配置,双方系统之间不使用LACP进行协商。

正常情况下所有链路都是活动链路,该模式下所有活动链路都参与数据的转发,平均分担流量,如果某条活动链路故障,链路聚合组自动在剩余的活动链路中平均分担流量。

当聚合的两端设备中存在一个不支持LACP协议时,可以使用手工模式。

手工模式下的缺陷不足

image.png

为了使链路聚合接口正常工作,必须保证本端链路聚合接口中所有成员接口的对端接口:

  • 属于同一设备

  • 加入同一链路聚合接口

手工模式下,设备间没有报文交互,因此只能通过管理员人工确认。

image.png

手动模式下,设备只能通过物理层状态判断对端接口是否正常工作。

配置示例:

# 创建链路聚合组
[Huawei] interface eth-trunk trunk-id

# 配置链路聚合模式,Mode lacp配置链路聚合模式为lacp模式,mode manual load-balance配置链路聚合模式为手工模式。
[Huawei-Eth-Trunk1] mode {
   
   lacp | manual load-balance }

# 将接口加入链路聚合组中(Eth-Trunk视图),可以在聚合组添加也可以手动进入物理以太网接口添加
[Huawei-Eth-Trunk1] trunkport interface-type {
   
    interface-number}

# 将接口加入链路聚合组中(以太网接口视图)
[Huawei-GigabitEthernet0/0/1] eth-trunk trunk-id

# 查看聚合口状态
[LSW2]display eth-trunk 1

# 查看接口信息
[LSW1]display interface Eth-Trunk 1

手工配置链路聚合只能人工判断接口状态,不能检测链路状态,默认所有链路都是活动链路。

LACP模式

LACP模式:采用LACP协议的一种链路聚合模式。设备间通过链路聚合控制协议数据单元(Link Aggregation Control Protocol Data Unit,LACPDU)进行交互,通过协议协商确保对端是同一台设备、同一个聚合接口的成员接口。

LACPDU报文中包含设备优先级、MAC地址、接口优先级、接口号等。

系统优先级:确定哪一边设备为主,另外一端根据主动端进行协商

image.png

LACP模式下,两端设备所选择的活动接口数目必须保持一致,否则链路聚合组就无法建立。此时可以使其中一端成为主动端,另一端(被动端)根据主动端选择活动接口。通过系统LACP优先级确定主动端,值越小优先级越高,如果优先级一样则MAC地址小的为主动端。

接口优先级:优先级越小越优先,一致就比较接口ID,如G1/0/1,G1/0/2,越小越优先。

image.png

选出主动端后,两端都会以主动端的接口优先级来选择活动接口,优先级高的接口将优先被选为活动接口。接口LACP优先级值越小,优先级越高。

最大活动接口数:LACP模式可以选择性启用活动接口数量,也就是控制带宽速率

image.png
image.png

LACP模式支持配置最大活动接口数目,当成员接口数目超过最大活动接口数目时会通过比较接口优先级、接口号选举出较优的接口成为活动接口,其余的则成为备份端口(非活动接口)。

当活动链路中出现链路故障时,可以从非活动链路中找出一条优先级最高(接口优先级、接口编号比较)的链路替换故障链路,实现总体带宽不发生变化、业务的不间断转发。

配置示例:

# 创建聚合口
interface Eth-Trunk1   
mode lacp-static       # 修改为lacp模式
trunkport Ethernet 0/0/1 to 0/0/3 # 添加接口

# 查看命令dis eth-trunk 1
# dis int eth-trunk 1

# 设置最大活动接口,其余为备份接口
max active-linknumber 2

# 使能允许不同速率端口加入同一Eth-Trunk接口的功能
[Huawei-Eth-Trunk1] mixed-rate link enable

# 配置系统LACP优先级
[Huawei] lacp priority priority

# 配置接口LACP优先级
[Huawei-GigabitEthernet0/0/1] lacp priority priority

# 配置最小活动接口数
[Huawei-Eth-Trunk1] least active-linknumber {
   
   number}

LACP选举过程

image.png
image.png
image.png
image.png

负载分担

image.png

在使用Eth-Trunk转发数据时,由于聚合组两端设备之间有多条物理链路,如果每个数据帧在不同的链路上转发,则有可能导致数据帧到达对端时间不一致,从而引起数据乱序。

Eth-Trunk推荐采用逐流负载分担的方式,即一条相同的流负载到一条链路,这样既保证了同一数据流的数据帧在同一条物理链路转发,又实现了流量在聚合组内各物理链路上的负载分担。

负载分担模式: Eth-trunk支持基于报文的IP地址或MAC地址来进行负载分担,可以配置不同的模式(本地有效,对出方向报文生效)将数据流分担到不同的成员接口上。

常见的模式有:源IP、源MAC、目的IP、目的MAC、源目IP、源目MAC。

实际业务中用户需要根据业务流量特征选择配置合适的负载分担方式。业务流量中某种参数变化越频繁,选择与此参数相关的负载分担方式就越容易实现负载均衡。

image.png

链路聚合是通过在设备间连接多条线实现链路可靠性,但是会因为STP导致阻塞,因此需要链路聚合实现逻辑聚合成一个端口。链路聚合有两种方式,手动模式需要管理员确定端口状态变更,LACP通过报文实现协商,根据系统优先级和接口优先级确定主动端,可以配置最大接口数实现提高带宽以及链路备份功能。实际数据在还是在物理链路中传输,因此可能多条数据流走的接口不一致,可以按需选择合适的负载分担模式。

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
7月前
|
人工智能 数据中心 云计算
|
5月前
|
网络协议 网络架构
以太网链路连接 和 ISIS/OSPF等路由协议关系
以太网链路连接 和 ISIS/OSPF等路由协议关系
54 0
|
2月前
|
负载均衡 算法 数据中心
网络中的链路聚合是什么意思?
【10月更文挑战第12天】
60 0
网络中的链路聚合是什么意思?
|
4月前
|
存储 缓存 NoSQL
【Azure Redis 缓存】Azure Cache for Redis 专用终结点, 虚拟网络, 公网访问链路
【Azure Redis 缓存】Azure Cache for Redis 专用终结点, 虚拟网络, 公网访问链路
|
5月前
|
网络协议 算法 程序员
网络必修课:以太网报文格式详解
嗨,大家好!今天,我要带大家深入了解以太网报文格式,这是现代网络通信的重要基础。无论你是网络工程师、开发者,还是对技术感兴趣的朋友,这篇文章都将为你揭开以太网的神秘面纱,让你更好地理解和应用这一关键技术。准备好了吗?让我们开始吧!
149 4
|
5月前
|
机器学习/深度学习 大数据 计算机视觉
【YOLOv8改进 - 特征融合】 GELAN:YOLOV9 通用高效层聚合网络,高效且涨点
YOLOv8专栏探讨了深度学习中信息瓶颈问题,提出可编程梯度信息(PGI)和广义高效层聚合网络(GELAN),改善轻量级模型的信息利用率。GELAN在MS COCO数据集上表现优越,且PGI适用于不同规模的模型,甚至能超越预训练SOTA。[论文](https://arxiv.org/pdf/2402.13616)和[代码](https://github.com/WongKinYiu/yolov9)已开源。核心组件RepNCSPELAN4整合了RepNCSP块和卷积。更多详情及配置参见相关链接。
|
4月前
|
网络协议
网络工程师必看 | 某高校实验作业:以太网帧分析
网络工程师必看 | 某高校实验作业:以太网帧分析
|
4月前
|
算法
蜂窝网络下行链路的覆盖率和速率性能matlab仿真分析
此程序在MATLAB2022a环境下运行,基于随机几何模型评估蜂窝网络的下行链路覆盖率和速率性能。通过模拟不同场景下的基站(BS)配置与噪声情况,计算并绘制了各种条件下的信号干扰加噪声比(SINR)阈值与覆盖率概率的关系图。结果显示,在考虑噪声和不同基站分布模型时,覆盖率有显著差异,提出的随机模型相较于传统网格模型更为保守但也更加贴合实际基站的分布情况。
|
6月前
|
网络虚拟化
以太网链路聚合与交换机堆叠、集群
以太网链路聚合与交换机堆叠、集群
|
6月前
|
域名解析 网络协议 程序员
网络原理(7)——以太网数据帧和DNS协议(数据链路层和应用层)
网络原理(7)——以太网数据帧和DNS协议(数据链路层和应用层)
226 0