DPDK-VPP 学习笔记-06 bond 链路聚合 LACP

2023-05-16

DPDK-VPP 学习笔记-06 bond 链路聚合 LACP

本笔记主要测试VPP与交换机链路聚合配置&状态:

  • Switch: HW CE6880
  • NIC: Mellanox CX5

链路聚合简介

以太网链路聚合(Eth-Trunk)简称链路聚合,它通过将多条以太网物理链路捆绑在一起成为一条逻辑链路,从而实现增加链路带宽的目的。同时,这些捆绑在一起的链路通过相互间的动态备份,可以有效地提高链路的可靠性。使用上因系统不同, PortChannel & Bond 等都是链路聚合的别名。
在这里插入图片描述
链路聚合工作模式分为手工负载分担模式和LACP模式。

手工负载分担模式

手工负载分担模式下,链路聚合的建立、成员接口的加入由手工配置,没有链路聚合控制协议的参与。该模式下所有活动链路都参与数据的转发,平均分担流量,因此称为负载分担模式。如果某条活动链路故障,链路聚合组自动在剩余的活动链路中平均分担流量。当需要在两个直连设备间提供一个较大的链路带宽而设备又不支持LACP协议时,可以使用手工负载分担模式。

LACP模式

链路聚合协议LACP分为静态LACP模式和动态LACP模式

静态LACP模式

静态LACP模式下,链路聚合接口的建立,成员接口的加入,都是由手工配置完成的。但与手工负载分担模式链路聚合不同的是,该模式下活动接口的选择由LACP协议报文负责。也就是说,当把一组接口加入链路聚合接口后,这些成员接口中哪些接口作为活动接口,哪些接口作为非活动接口还需要经过LACP协议报文的协商确定。

静态LACP模式也称为M∶N模式。这种方式同时可以实现负载分担和冗余备份的双重功能。在链路聚合组中M条链路处于活动状态,这些链路负责转发数据并进行负载分担,另外N条链路处于非活动状态作为备份链路,不转发数据。当M条链路中有链路出现故障时,系统会从N条备份链路中选择优先级最高的接替出现故障的链路,同时这条链路状态变为活动状态开始转发数据。

动态LACP模式

静态LACP模式和动态LACP模式在LACP协议交互方面没有区别,区别在于两种模式在LACP协商失败后的处理不一致:
◾静态LACP模式下,LACP协商失败后链路聚合端口变为Down,不能转发数据。
◾动态LACP模式,LACP协商失败后链路聚合端口变为Down,但其成员口继承链路聚合端口的VLAN属性状态变为Indep,可独立进行二层数据转发。

当部署动态LACP模式链路聚合接口的设备能够收到对端的LACP协议报文时,两端设备将通过LACP协议报文进行聚合参数协商。协商成功后的聚合链路功能与两端都配置为静态LACP模式链路聚合接口的链路一样。

VPP bond LACP

VPP bond lacp 模式等同于HW交换机中 LACP模式 , 支持静态mode lacp-static 与动态mode lacp-dynamic 两种模式.

vpp# create bond mode lacp  load-balance l23 
BondEthernet0
vpp# bond add BondEthernet0 HundredGigabitEthernet5/0/0 
vpp# bond add BondEthernet0 HundredGigabitEthernet5/0/1 
vpp# set int state BondEthernet0 up 
vpp# set int ip address BondEthernet0  10.245.120.42/24 
vpp# show bond details
BondEthernet0
  mode: lacp
  load balance: l23
  number of active members: 0
  number of members: 2
    HundredGigabitEthernet5/0/0
    HundredGigabitEthernet5/0/1
  device instance: 0
  interface id: 0
  sw_if_index: 3
  hw_if_index: 3
vpp# 
vpp# show int
              Name               Idx    State  MTU (L3/IP4/IP6/MPLS)     Counter          Count     
BondEthernet0                     3      up          1500/0/0/0     rx packets                  2590
                                                                    rx bytes                  321102
                                                                    tx packets                     1
                                                                    tx bytes                      66
HundredGigabitEthernet5/0/0       1      up          1500/0/0/0     rx packets                  1310
                                                                    rx bytes                  161986
                                                                    tx packets                    78
                                                                    tx bytes                    8966
                                                                    drops                       1294
HundredGigabitEthernet5/0/1       2      up          1500/0/0/0     rx packets                  1306
                                                                    rx bytes                  161626
                                                                    tx packets                    54
                                                                    tx bytes                    6638
                                                                    drops                       1295
local0                            0     down          0/0/0/0       drops                          1
vpp# 

静态LACP模式

HW CE8850 交换配置:

[~HUAWEI-Eth-Trunk20]disp this
#
interface Eth-Trunk20
 undo portswitch
 ip address 10.245.120.1 255.255.255.0
 mode lacp-static
#
return
[~HUAWEI-Eth-Trunk20]disp eth-trunk 20
Eth-Trunk20's state information is:
Local:
LAG ID: 20                      Working Mode: Static
Preempt Delay: Disabled         Hash Arithmetic: profile default
System Priority: 32768          System ID: 04bd-706e-b951
Least Active-linknumber: 1      Max Active-linknumber: 16 
Operating Status: up            Number Of Up Ports In Trunk: 2
Timeout Period: Slow          
--------------------------------------------------------------------------------
ActorPortName          Status   PortType PortPri PortNo PortKey PortState Weight
100GE1/0/3             Selected 100GE    32768   2      5201    10111100  1     
100GE1/0/27            Selected 100GE    32768   1      5201    10111100  1     

Partner:
--------------------------------------------------------------------------------
ActorPortName          SysPri   SystemID        PortPri PortNo PortKey PortState
100GE1/0/3             65535    9803-9b97-5076  255     1      3       11111100 
100GE1/0/27            65535    9803-9b97-5076  255     2      3       11111100 

VPP lacp 状态:

vpp# show lacp        
                                                        actor state                      partner state                   
interface name            sw_if_index  bond interface   exp/def/dis/col/syn/agg/tim/act  exp/def/dis/col/syn/agg/tim/act
HundredGigabitEthernet5/0 2            BondEthernet0      0   0   1   1   1   1   1   1    0   0   1   1   1   1   0   1
  LAG ID: [(ffff,98-03-9b-97-50-76,0003,00ff,0002), (8000,04-bd-70-6e-b9-51,1451,8000,0001)]
  RX-state: CURRENT, TX-state: TRANSMIT, MUX-state: COLLECTING_DISTRIBUTING, PTX-state: PERIODIC_TX
HundredGigabitEthernet5/0 1            BondEthernet0      0   0   1   1   1   1   1   1    0   0   1   1   1   1   0   1
  LAG ID: [(ffff,98-03-9b-97-50-76,0003,00ff,0001), (8000,04-bd-70-6e-b9-51,1451,8000,0002)]
  RX-state: CURRENT, TX-state: TRANSMIT, MUX-state: COLLECTING_DISTRIBUTING, PTX-state: PERIODIC_TX

动态LACP模式

HW CE8850 交换配置:

[~HUAWEI-Eth-Trunk20]disp this
#
interface Eth-Trunk20
 undo portswitch
 ip address 10.245.120.1 255.255.255.0
 mode lacp-dynamic
#
return
[~HUAWEI-Eth-Trunk20]disp eth-trunk 20
Eth-Trunk20's state information is:
Local:
LAG ID: 20                      Working Mode: Dynamic
Preempt Delay: Disabled         Hash Arithmetic: profile default
System Priority: 32768          System ID: 04bd-706e-b951
Least Active-linknumber: 1      Max Active-linknumber: 16 
Operating Status: up            Number Of Up Ports In Trunk: 2
Timeout Period: Slow          
--------------------------------------------------------------------------------
ActorPortName          Status   PortType PortPri PortNo PortKey PortState Weight
100GE1/0/3             Selected 100GE    32768   2      5201    10111100  1     
100GE1/0/27            Selected 100GE    32768   1      5201    10111100  1     

Partner:
--------------------------------------------------------------------------------
ActorPortName          SysPri   SystemID        PortPri PortNo PortKey PortState
100GE1/0/3             65535    9803-9b97-5076  255     1      3       11111100 
100GE1/0/27            65535    9803-9b97-5076  255     2      3       11111100 

VPP lacp 状态:

vpp# show lacp                            
                                                        actor state                      partner state                   
interface name            sw_if_index  bond interface   exp/def/dis/col/syn/agg/tim/act  exp/def/dis/col/syn/agg/tim/act
HundredGigabitEthernet5/0 2            BondEthernet0      0   0   1   1   1   1   1   1    0   0   1   1   1   1   0   1
  LAG ID: [(ffff,98-03-9b-97-50-76,0003,00ff,0002), (8000,04-bd-70-6e-b9-51,1451,8000,0001)]
  RX-state: CURRENT, TX-state: TRANSMIT, MUX-state: COLLECTING_DISTRIBUTING, PTX-state: PERIODIC_TX
HundredGigabitEthernet5/0 1            BondEthernet0      0   0   1   1   1   1   1   1    0   0   1   1   1   1   0   1
  LAG ID: [(ffff,98-03-9b-97-50-76,0003,00ff,0001), (8000,04-bd-70-6e-b9-51,1451,8000,0002)]
  RX-state: CURRENT, TX-state: TRANSMIT, MUX-state: COLLECTING_DISTRIBUTING, PTX-state: PERIODIC_TX

VPP bond XOR

VPP bond xor 模式等同于HW交换机中 手工负载分担模式 & mode manual load-balance 也是链路聚合的默认模式.

HW CE8850交换机配置:

[~HUAWEI-Eth-Trunk20]disp this
#
interface Eth-Trunk20
 undo portswitch
 ip address 10.245.120.1 255.255.255.0
#
return
[~HUAWEI-Eth-Trunk20]disp eth-trunk 20
Eth-Trunk20's state information is:
Working Mode: Normal        Hash Arithmetic: profile default
Least Active-linknumber: 1  Max Bandwidth-affected-linknumber: 16
Operating Status: up        Number of Up Ports in Trunk: 2
--------------------------------------------------------------------------------
PortName                      Status      Weight
100GE1/0/3                    Up          1          
100GE1/0/27                   Up          1       

VPP 配置:

vpp# set int state  HundredGigabitEthernet5/0/0 up
vpp# set int state  HundredGigabitEthernet5/0/1 up
vpp# create bond mode xor  load-balance l23
vpp# bond add BondEthernet0 HundredGigabitEthernet5/0/0
vpp# bond add BondEthernet0 HundredGigabitEthernet5/0/1
vpp# set int state BondEthernet0 up
vpp# set int ip address  BondEthernet0 10.245.120.42/24
vpp# show bond details
BondEthernet0
  mode: xor
  load balance: l23
  number of active members: 2
    HundredGigabitEthernet5/0/0
    HundredGigabitEthernet5/0/1
  number of members: 2
    HundredGigabitEthernet5/0/0
    HundredGigabitEthernet5/0/1
  device instance: 0
  interface id: 0
  sw_if_index: 3
  hw_if_index: 3
vpp# show version 
vpp v21.01-rc1~3-gf097300c2 built by root on fc29 at 2021-01-21T06:11:27
vpp# show int
              Name               Idx    State  MTU (L3/IP4/IP6/MPLS)     Counter          Count     
BondEthernet0                     3      up          1500/0/0/0     rx packets                    26
                                                                    rx bytes                    2510
                                                                    tx packets                    25
                                                                    tx bytes                    2394
                                                                    drops                          1
                                                                    ip4                           25
HundredGigabitEthernet5/0/0       1      up          1500/0/0/0     rx packets                    16
                                                                    rx bytes                    1530
                                                                    tx packets                    25
                                                                    tx bytes                    2394
HundredGigabitEthernet5/0/1       2      up          1500/0/0/0     rx packets                    10
                                                                    rx bytes                     980
local0                            0     down          0/0/0/0       drops                          1
vpp# 

参考文档

VPP vnet bonding
CloudEngine 12800, 12800E V200R005C00 配置指南-以太网链路聚合配置
链路聚合Eth-Trunk

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

DPDK-VPP 学习笔记-06 bond 链路聚合 LACP 的相关文章

随机推荐

  • 什么是makefile?教你简单编写和使用Makefile

    什么是Makefile xff1f Makefile可以简单的理解成一个工程文件的编译规则 Makefile文件描述了Linux系统下C C 43 43 项目工程的编译规则 xff0c 它的作用是用来自动化编译C C 43 43 的项目 一
  • 《程序员面试金典(第6版)》面试题 16.14. 最佳直线(向量,C++)

    题目描述 给定一个二维平面及平面上的 N 个点列表Points xff0c 其中第i个点的坐标为Points i 61 Xi Yi 请找出一条直线 xff0c 其通过的点的数目最多 设穿过最多点的直线所穿过的全部点编号从小到大排序的列表为S
  • 制作Ubuntu启动盘并安装ros的学习笔记

    本菜鸡刚开始学习ros xff0c 之前一直用虚拟机 xff0c 但但是配置极其麻烦 xff0c 容易出现各种错误 xff0c 对新手极其不友好 亲测做一个Ubuntu的启动盘很是稳定 为了后续学习时回看 xff0c 记录一下遇到的问题以及
  • Ubuntu22.04没有ttyUSB(无法访问 ‘/dev/ttyUSB‘: 没有那个文件或目录)问题解决

    无法访问 dev ttyUSB 没有那个文件或目录 环境 xff1a ubuntu22 04 xff0c 使用需求为USB转串口 问题描述 在给串口读写权限时 xff0c 出现问题 xff1a 无法访问 dev ttyUSB0 没有那个文件
  • 光流(optical flow)基础概念以及典型算法

    光流 xff08 optical flow xff09 基础概念以及典型算法 文章目录 光流 xff08 optical flow xff09 基础概念以及典型算法什么是光流 xff1f 一 传统经典光流算法 xff1a Lucas Kan
  • PX4无人机安装问题及解决方案

    文章目录 1 git clone1 git clone fatal error2 PX4源码下载很慢 2 ROS安装1 设置密钥2 xff09 E 无法定位软件包 ros melodic desktop full3 sudo apt ins
  • 玩转k8s(四)—— 通过Service访问Pod

    我们不应该期望k8s Pod是健壮的 xff0c 而是要假设Pod中的容器很可能因为各种原因发生故障而死掉 Deployment等Controller会通过动态的创建和销毁Pod来保证应用整体的健壮性 换句话说 xff0c Pod是脆弱的
  • STM32之IO模拟串口篇

    概述 xff1a 硬件 xff1a 基于stm32f767igt6水星板开发 xff1b 软件 xff1a 使用了RT Thread实时操作系统 xff0c 两个空闲IO口 PE2用作串口TX端 xff0c 搭配一个定时器控制发送时序 xf
  • BPMN2.0 任务-脚本任务

    描述 脚本任务 script task 是自动执行的活动 当流程执行到达脚本任务时 会执行相应的脚本 脚本任务用左上角有一个小 脚本 图标的标准BPMN 2 0任务 圆角矩形 表示 脚本任务使用script与scriptFormat元素定义
  • 最短路径问题——基于Dijkstra算法和Floyd算法的最短路径问题

    目录 1 算法介绍 xff08 1 xff09 Dijkstra Algorithm xff08 迪杰斯特拉算法 xff09 xff08 2 xff09 Floyd Algorithm xff08 佛洛依德算法 xff09 xff08 3
  • 2.1.2 进程的状态与转换

    目录 知识总览 1 三种基本状态 xff08 1 xff09 运行态 xff08 Running xff09 xff08 2 xff09 就绪态 xff08 Ready xff09 xff08 3 xff09 阻塞态 xff08 Waiti
  • 合并排序与快速排序算法

    文章目录 算法介绍代码实现1 合并排序2 快速排序 总结 算法介绍 合并排序与快速排序是排序算法中常用的两种排序算法 xff0c 合并排序把数据分为两段 xff0c 从两段中逐个选最小的元素移入新数据的末尾 xff1b 快速排序是在序列中挑
  • 2进制、8进制、10进制、16进制相互转换

    文章目录 介绍1 二进制转其他进制2 八进制转其他进制3 十进制转其他进制4 十六进制转其他进制总结 介绍 百度百科 xff1a 进制也就是进位计数制 xff0c 是人为定义的带进位的计数方法 xff08 有不带进位的计数方法 xff0c
  • Hadoop学习笔记--HBase相关操作指令

    文章目录 引言0 HBase的启动与停止1 创建表2 删除表3 表的其他操作3 1 修改表结构3 2 查看表结构3 3 显示所有用户定义的表3 4 查询表是否存在3 5 查询表是否可用3 6 查询表中记录数 4 插入数据4 1 插入单条数据
  • Hadoop学习笔记--MapReduce

    文章目录 引言1 经典案例分析 xff1a WordCount1 1 Map阶段 xff1a TokenizerMapper类1 2 Reduce阶段 xff1a IntSumReduce类1 3 Driver阶段 xff1a main x
  • Hadoop学习笔记--YARN

    文章目录 引言1 YARN的优势1 1 可扩展性 xff08 Scalability xff09 1 2 可用性 xff08 Availability xff09 1 3 利用率 xff08 Utilization xff09 1 4 多租
  • scala编程--计算级数&统计学生成绩

    目录 案例1 xff1a 计算级数1 1 案例要求1 2 实现代码 案例2 xff1a 统计学生成绩1 1 案例要求1 2 实现代码 总结 案例1 xff1a 计算级数 1 1 案例要求 级数计算函数实现较为简单 xff0c 这里不再赘述
  • RDD本地文件系统读入显示文件不存在fileNotExit

    问题 在从本地文件系统读入数据创建RDD时 xff0c 执行行动操作 xff0c 显示文件不存在 解决方案 从本地文件系统读入时 xff0c 需在所有节点的相同目录下存在该文件 xff0c 如读取文件在 file span class to
  • spark-shell报错:java.io.IOException: Failed to replace a bad datanode on the existing pipeline due to

    目录 问题报错信息原因解决方案 问题 spark shell在执行一段时间后报错 xff1a java io IOException Failed to replace a bad datanode on the existing pipe
  • DPDK-VPP 学习笔记-06 bond 链路聚合 LACP

    DPDK VPP 学习笔记 06 bond 链路聚合 LACP 本笔记主要测试VPP与交换机链路聚合配置 amp 状态 Switch HW CE6880NIC Mellanox CX5 链路聚合简介 以太网链路聚合 Eth Trunk 简称