LLDP 基本原理

LLDP 简介

定义

LLDP(Link Layer Discovery Protocol,链路层发现协议)是 IEEE 802.1ab 中定义的第二层发现(Layer 2 Discovery)协议。

LLDP 提供了一种标准的链路层发现方式,可以将本端设备的主要能力、管理地址、设备标识、接口标识等信息封装到 LLDP 报文中传递给邻居节点,邻居节点在收到这些信息后将其以标准 MIB(Management Information Base,管理信息库)的形式保存起来,供 NMS(Network Management System,网络管理系统)查询及判断链路的通信状况。

目的

随着网络规模越来越大,网络设备种类繁多,并且各自的配置错综复杂,对网络管理能力的要求也越来越高。传统网络管理系统多数只能分析到三层网络拓扑结构,无法确定网络设备的详细拓扑信息、是否存在配置冲突等。因此需要有一个标准的二层信息交流协议。

LLDP 提供了一种标准的链路层发现方式。通过 LLDP 获取的设备二层信息能够快速获取相连设备的拓扑状态;显示出客户端、交换机、路由器、应用服务器以及网络服务器之间的路径;检测设备间的配置冲突、查询网络失败的原因。

用户可以通过使用网管系统,对支持运行 LLDP 协议的设备进行链路状态监控,在网络发生故障的时候快速进行故障定位。
通过在网络中部署 LLDP 协议,既能掌握更详细的网络拓扑信息以及网络拓扑变化信息,还能及时发现网络中实际存在的不合理的配置,这些信息有助于用户实时监控网络状态,有效提升网络的安全性和稳定性。

LLDP 基本原理

LLDP 可以将本地设备的信息发送给远端设备,本地设备将收到的远端设备信息以标准 MIB (Management Information Base,管理信息库) 的形式保存起来。

LLDP 协议规定设备的每个接口上都有四个 MIB 库,其中最主要的两个为 LLDP Local System MIB(LLDP 本地系统 MIB)和 LLDP Remote System MIB(LLDP 远端系统 MIB),分别存储着本端设备和邻居节点的状态信息,包括设备 ID、接口 ID、系统名称、系统描述、接口描述、设备能力、网络管理地址。

LLDP 基本原理如图所示

在这里插入图片描述

LLDP 基本实现原理如下:

  1. LLDP 模块通过 LLDP 代理与设备上物理拓扑 MIB、实体 MIB、接口 MIB 以及其他 MIB 的交互,来更新自己的 LLDP 本地系统 MIB,以及本地设备自定义的 LLDP 扩展 MIB。

  2. 将本地设备信息封装成 LLDP 帧发送给远端设备。

  3. 接收远端设备发过来的 LLDP 帧,更新自己的 LLDP 远端系统 MIB,以及远端设备自定义的 LLDP 扩展 MIB。

通过 LLDP 代理收发 LLDP 帧,设备就很清楚地知道远端设备的信息,包括连接的是远端设备的哪个接口、远端设备的 MAC 地址等信息。

LLDP 代理主要完成如下工作

  • 维护 LLDP 本地系统 MIB 信息。

  • 向邻居节点发送 LLDP 帧,通告本端设备的状态信息。

  • 识别并解析收到的邻居节点发送的 LLDP 帧,维护 LLDP 远端系统 MIB 的信息。

  • LLDP 本地系统 MIB 或 LLDP 远端系统 MIB 的信息发生变化时,向网管发送 LLDP 告警。

LLDP 拓扑发现

在 DeviceA 和 DeviceB 已配置 LLDP 功能的情况下,介绍 LLDP 拓扑发现的实现过程。

LLDP 拓扑发现图
在这里插入图片描述

  1. DeviceA 将本端的状态信息封装成 LLDP 报文,发送给邻居设备 DeviceB。

  2. DeviceB 解析接收到的 LLDP 报文,并将该报文中的关于 DeviceA 的信息存储到设备上的远端系统 MIB 中,供 NMS 提取拓扑信息使用。

  3. 同样,DeviceB 也将本端的状态信息封装成 LLDP 报文发送给 DeviceA,DeviceA 解析接收到的 LLDP 报文,并将该报文中的关于 DeviceB 的信息存储到设备上的远端系统 MIB 中,供 NMS 提取拓扑信息使用。

  4. NMS 通过与 DeviceA 和 DeviceB 交互 SNMP (Simple Network Management Protocol,简单网络管理协议)
    报文,从两者的 MIB 库中提取本地信息和邻居信息并进行拓扑分析,最终发现整网的拓扑结构。

LLDP 报文格式

  • 封装了 LLDP 数据单元 LLDPDU(LLDP Data Unit)的以太网报文称为 LLDP 报文。其封装格式有两种:Ethernet II 和 SNAP(Subnetwork Access Protocol,子网访问协议),目前设备支持的封装格式为 Ethernet II。

LLDP 报文格式如图所示

在这里插入图片描述
LLDP 报文中相关字段的解释如表所示

字段说明
Destination MAC address目的 MAC 地址,为固定的组播 MAC 地址 0x0180-C200-000E。
Source MAC address源 MAC 地址,为接口 MAC 地址或设备桥 MAC 地址(如果有接口地址则使用接口 MAC 地址,否则使用设备桥 MAC 地址)。
Type报文类型,固定为 0x88CC。
LLDPDULLDP 数据单元,LLDP 信息交换的主体。
FCS(Frame Check Sequence)帧校验序列。

LLDPDU

LLDPDU 是封装在 LLDP 报文中的数据单元。

组成 LLDPDU 之前,设备先将本地信息封装成 TLV(Type-Length-Value)格式,再由若干个 TLV 组合成一个 LLDPDU,封装在 LLDP 报文的数据部分进行传送。用户可以根据需要将多种不同的 TLV 组合到 LLDPDU 中,设备根据这些不同的 TLV 来通告自己的状态信息,并且学习邻居节点的状态信息。

LLDPDU 的结构如图所示

在这里插入图片描述
LLDP 协议规定每个 LLDPDU 共可携带 28 种 TLV,且每个 LLDPDU 固定以 Chassis ID TLV、Port ID TLV 和 Time to Live TLV 开始,以 End of LLDPDU TLV 为结束。其中 Chassis ID TLV、Port ID TLV 和 Time to Live TLV 为必选的 TLV,其他则为可选 TLV,用户可以根据需要自行决定是否要组合到 LLDPDU 中发送。

TLV

TLV 是组成 LLDPDU 的最小单元,表示一个对象的类型、长度和信息。

TLV 的结构如图所示
在这里插入图片描述

  • TLV Type 表示 TLV 的类型,它占 7 个 bits。每个 TLV 的类型值不同,比如 End of LLDPDU TLV 的类型值为 0,Chassis ID TLV 的类型值为 1 等。

  • TLV information string length 表示 TLV 内容的长度,它占 9 个 bit。

  • TLV information string 表示 TLV 的内容,最大支持 511bytes 长度的内容。

每个 TLV 代表设备的一种信息,例如设备 ID、接口 ID、管理地址等都各自对应 Chassis ID TLV、Port ID TLV、Management Address TLV 等固定的 TLV。

LLDP 可以封装的 TLV 类型包括基本 TLV、802.1 组织定义的 TLV、802.3 组织定义的 TLV。

  • 基本 TLV:基本 TLV 是网络设备管理的一组基础 TLV。

  • 基本 TLV 说明

TLV 名称TLV 类型说明是否必须发布
End of LLDPDU TLV0标识 LLDPDU 结束。
Chassis ID TLV1标识发送设备的桥 MAC 地址。
Port ID TLV2标识 LLDPDU 发送端的接口。
Time To Live TLV3标识本设备信息在邻居节点上的存活时间。
Port Description TLV4标识以太网接口的描述信息。
System Name TLV5标识设备的名称。
System Description TLV6标识系统描述信息。
System Capabilities TLV7标识系统的主要功能以及有哪些主要功能被启用。
Management Address TLV8标识管理地址。
Reserved9~126保留,用作特殊用途。
  • 组织定义 TLV:组织定义 TLV 是由标准组织定义的 TLV,主要包括 IEEE 802.1 组织定义的 TLV 和 IEEE 802.3 组织定义的 TLV,用于增强对网络设备的管理,可根据实际需要配置是否在 LLDPDU 中发送。

IEEE 802.1 组织定义的 TLV 说明

TLV 名称TLV 类型说明
Reserved0保留,用作特殊用途。
Port And Protocol VLAN ID TLV1标识接口的协议 VLANID。
VLAN Name TLV3标识接口 VLAN 名称。
Protocol Identity TLV4标识接口支持的协议类型。
Reserved5~255保留,用作特殊用途。

IEEE 802.3 组织定义的 TLV 说明

TLV 名称TLV 类型说明
Reserved0保留,用作特殊用途。
MAC/PHY Configuration/Status TLV1标识接口是否支持速率自动协商、是否已启用自动协商功能以及接口当前的速率和双工状态。
Link Aggregation TLV3标识接口是否支持链路聚合以及是否已启用链路聚合。
Maximum Frame Size TLV4标识接口支持的最大帧长度,取接口的最大传输单元 MTU(Max Transmission Unit)。
Reserved5~255保留,用作特殊用途。

LLDLLDP 四种工作模式

模式工作行为
Tx只发送 LLDP 报文
Rx只接收 LLDP 报文
Tx/Rx既发送也接收 LLDP 报文
Disable既不发送也不接收 LLDP 报

LLDP 功能启用后,默认的工作模式为 Tx/Rx 模式。

说明

当接口的 LLDP 工作模式发生变化时,接口将对协议状态机进行初始化操作。为了避免接口工作模式频繁改变而导致接口不断执行初始化操作,设备支持配置接口初始化延迟时间,当接口工作模式改变时延迟一段时间再执行初始化操作。

下面介绍 LLDP 工作模式下,LLDP 报文的发送和接收机制。

  • LLDP 报文的发送机制

  • 一般情况下,启用 LLDP 功能后,设备会周期性地向邻居节点发送 LLDP 报文。如果设备的本地配置发生变化,则立即发送 LLDP 报文,将本地信息的变化情况尽快通知给邻居节点。为了防止本地信息的频繁变化而引起 LLDP 报文的大量发送,设备支持配置接口发送 LLDP 报文的延迟时间,每发送一个 LLDP 报文后都延迟一段时间后再继续发送下一个报文。

当设备发现一个新邻居(即接收到一个新的 LLDP 报文且本地没有保存该报文的发送方设备的信息),或者设备的 LLDP 功能由打开状态变为关闭,或者设备的接口状态由 Down 变为 Up 的时候,为了让其他设备尽快发现本设备,设备支持快速发送机制,即将 LLDP 报文的发送周期缩短为 1 秒,并连续发送指定数量的 LLDP 报文后再恢复为正常的发送周期。

  • LLDP 报文的接收机制

  • 设备收到 LLDP 报文时,会对报文及其携带的 TLV 信息进行有效性检查,通过有效性检查后,将邻居信息保存到本地设备,并根据 LLDPDU 中携带的 TTL(Time To Live,生存时间) TLV 值,设置邻居信息在本地设备的老化时间,如果接收到的 LLDPDU 中的 TTL 值等于零,将立刻老化掉该邻居信息。

LLDP 缺省配置

LLDP 常见参数的缺省配置如表所示

参数缺省值
LLDP 功能全局未启用
在 LLDP 报文中发布的管理 IP 地址自动获取管理 IP 地址,管理 IP 地址未绑定任何接口
LLDP 允许发布的 TLV 类型发布除 Protocol Identity TLV 外的所有类型的 TLV
设备发送 LLDP 报文的周期30 秒
设备发送 LLDP 报文的延迟时间2 秒
设备本端状态信息在邻居节点中保持的时间倍数4
接口的 LLDP 功能初始化的延迟时间2 秒
设备向邻居节点快速发送 LLDP 报文的个数4
设备发送 LLDP 邻居信息变化告警的延迟时间5 秒

via: huawei

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/365242.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Wp-scan一键扫描wordpress网页(KALI工具系列三十二)

目录 1、KALI LINUX 简介 2、Wp-scan工具简介 3、信息收集 3.1 目标IP(服务器) 3.2kali的IP 4、操作实例 4.1 基本扫描 4.2 扫描已知漏洞 4.3 扫描目标主题 4.4 列出用户 4.5 输出扫描文件 4.6 输出详细结果 5、总结 1、KALI LINUX 简介 Kali Linux 是一…

决策树划分属性依据

划分依据 基尼系数基尼系数的应用信息熵信息增益信息增益的使用信息增益准则的局限性 最近在学习项目的时候经常用到随机森林,所以对决策树进行探索学习。 基尼系数 基尼系数用来判断不确定性或不纯度,数值范围在0~0.5之间,数值越低&#x…

shark云原生-日志管理体系-filebeat

文章目录 1. deploy 文件1.1 RBAC1.2. DaemonSet1.2.1. Elasticsearch 连接信息1.2.2. Volume 1.3. ConfigMap1.3.1. 日志收集路径1.3.2. 日志事件输出目标 2. 在控制平面节点上运行Filebeat3. 查看输出3.1. 关于处理器 processors 4. 日志收集配置4.1. 手动指定日志收集路径4.…

简单多状态DP问题

这里写目录标题 什么是多状态DP解决多状态DP问题应该怎么做?关于多状态DP问题的几道题1.按摩师2.打家劫舍Ⅱ3.删除并获得点数4.粉刷房子5.买卖股票的最佳时期含手冷冻期 总结 什么是多状态DP 多状态动态规划(Multi-State Dynamic Programming, Multi-St…

数据结构-顺序表的插入排序

顺序表的排序可以看作数组排序的拓展。基本逻辑和数组排序的逻辑大同小异。 由于顺序表中可以存放不同种的数据类型,进而和结构体排序又有相似之处。其中要注意的是(->)和(.)的区别。 -> 符号是针对指针进行的操…

实现了Map接口的HashMap

HashMap 底层主要由以下几个部分组成&#xff1a; 数组 (Node<K,V>[] table): 这是一个数组&#xff0c;存储的是链表的头节点。默认大小为 16。链表 (Linked List): 当发生哈希冲突时&#xff0c;即不同的键具有相同的哈希值&#xff0c;HashMap 使用链表来解决冲突。链…

计网之IP

IP IP基本认识 不使用NAT时&#xff0c;源IP地址和目的IP地址不变&#xff0c;只要源MAC和目的MAC地址在变化 IP地址 D类是组播地址&#xff0c;E类是保留地址 无分类地址CIDR 解决直接分类的B类65536太多&#xff0c;C类256太少a.b.c.d/x的前x位属于网路号&#xff0c;剩…

分治精炼宝库-----快速排序运用(⌯꒪꒫꒪)੭

目录 一.基本概念: 一.颜色分类&#xff1a; 二.排序数组&#xff1a; 三.数组中的第k个最大元素&#xff1a; 解法一&#xff1a;快速选择算法 解法二&#xff1a;简单粗暴优先级队列 四.库存管理Ⅲ&#xff1a; 解法一&#xff1a;快速选择 解法二&#xff1a;简单粗…

Github 2024-06-21 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-06-21统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量TypeScript项目3Python项目3Java项目2非开发语言项目2JavaScript项目1Rust项目1Dart项目1HTML项目1Vue项目1C++项目1TensorFlow: 机器学习的开源…

【Linux】IO多路复用——select,poll,epoll的概念和使用,三种模型的特点和优缺点,epoll的工作模式

文章目录 Linux多路复用1. select1.1 select的概念1.2 select的函数使用1.3 select的优缺点 2. poll2.1 poll的概念2.2 poll的函数使用2.3 poll的优缺点 3. epoll3.1 epoll的概念3.2 epoll的函数使用3.3 epoll的优点3.4 epoll工作模式 Linux多路复用 IO多路复用是一种操作系统的…

算力时代,算能(SOPHGO)的算力芯片/智算板卡/服务器选型

数字经济时代&#xff0c;算力成为支撑经济社会发展新的关键生产力&#xff0c;全球主要经济体都在加快推进算力战略布局。随着大模型持续选代&#xff0c;模型能力不断增强&#xff0c;带来算力需求持续增长。算力对数字经济和GDP的提高有显著的带动作用&#xff0c;根据IDC、…

EasyExcel数据导入

前言&#xff1a; 我先讲一种网上信息的获取方式把&#xff0c;虽然我感觉和后面的EasyExcel没有什么关系&#xff0c;可能是因为这个项目这个操作很难实现&#xff0c;不过也可以在此记录一下&#xff0c;如果需要再拆出来也行。 看上了网页信息&#xff0c;怎么抓到&#x…

C++:typeid4种cast转换

typeid typeid typeid是C标准库中提供的一种运算符&#xff0c;它用于获取类型的信息。它主要用于类型检查和动态类型识别。当你对一个变量或对象使用typeid运算符时&#xff0c;它会返回一个指向std::type_info类型的指针&#xff0c;这个信息包含了关于该类型名称、大小、基…

【嵌入式Linux】i.MX6ULL 时钟树——理论分析

文章目录 0. 时钟树结构0.1 参考手册 Chapter 18​: Clock Controller Module (CCM)0.2 时钟信号路径 1. 时钟源——晶振1.1 外部低频时钟 - CKIL1.1.1 CKIL 同步到 IPG_CLK 解释 1.2 外部高频时钟 - CKIH 和 内部振荡器1.3 总结1.4 缩写补充 2. PLL时钟2.1 i.MX6U 芯片 PLL 时…

【ESP32】打造全网最强esp-idf基础教程——14.VFS与SPIFFS文件系统

VFS与SPIFFS文件系统 这几天忙着搬砖&#xff0c;差点没时间更新博客了&#xff0c;所谓一日未脱贫&#xff0c;打工不能停&#xff0c;搬砖不狠&#xff0c;明天地位不稳呀。 不多说了&#xff0c;且看以下内容吧~ 一、VFS虚拟文件系统 先来看下文件系统的定义&#x…

力扣SQL50 连续出现的数字 distinct

Problem: 180. 连续出现的数字 &#x1f468;‍&#x1f3eb; 力扣官解 Code SELECT DISTINCTl1.Num AS ConsecutiveNums FROMLogs l1,Logs l2,Logs l3 WHEREl1.Id l2.Id - 1AND l2.Id l3.Id - 1AND l1.Num l2.NumAND l2.Num l3.Num ;

Unity实现简单的MVC架构

文章目录 前言MVC基本概念示例流程图效果预览后话 前言 在Unity中&#xff0c;MVC&#xff08;Model-View-Controller&#xff09;框架是一种架构模式&#xff0c;用于分离游戏的逻辑、数据和用户界面。MVC模式可以帮助开发者更好地管理代码结构&#xff0c;提高代码的可维护性…

简单体验一下AI训练的过程

推荐一个站点 http://playground.tensorflow.org 有什么优点呢 这个是tensorflow官方的体验站点&#xff0c;以图形化的方式给出了训练过程中所需的各种因素。

帝国CMS(EmpireCMS)漏洞复现

简介 《帝国网站管理系统》英文译为Empire CMS&#xff0c;简称Ecms&#xff0c;它是基于B/S结构&#xff0c;且功能强大而帝国CMS-logo易用的网站管理系统。 帝国CMS官网&#xff1a;http://www.phome.net/ 参考相关漏洞分析文章&#xff0c;加上更详细的渗透测试过程。 参考…

计算机网络之体系结构

上节内容&#xff1a;数据通信原理 1.计算机网络体系结构 体系结构: 研究系统中各组成成分及其关系的一门学科。 计算机网络体系结构: 定义和描述一组用于计算机及其通信设施之间互连的标准和规范的集合&#xff0c;遵循这组规范可以很方便地实现计算机设备之间的通信。 相互…