STP知识总结

news2024/9/22 19:30:11

目录

生成树协议

导致问题

生成树

存在算法

1、802.1D

接口状态

收敛时间

结构变化

802.1D 缺点

2、PVST  cisco私有

3、PVST +

缺点

4、快速生成树

快速原理     

边缘接口

5、MSTP/MST/802.1S


生成树协议

        生成树协议是一种工作在OSI网络模型中第二层(数据链路层)的通信议,主要应用是为了防止交换机冗余链路产生的环路,确保以太网中无环路的逻辑拓扑结构

作用

        避免广播风暴和占用大量交换机资源

        生成树协议通过在交换机中根据算法切断多条链路只保留一条活动链路,从而确保任意两个交换机之间只有一条单一的活动链路,实现了网络的可靠性和稳定性

导致问题

【1】广播风暴

【2】MAC地址表翻滚  ——  在一台交换机上,同一个MAC地址只能映射唯一的接口;但同一个接口可以映射多个不同的MAC地址

【3】同一数帧的复制拷贝

【4】以上3个条件最终导致设备工作过载,导致重启保护

生成树

        在一个二层交换网络中,生成一棵树型结构,逻辑的阻塞部分接口,使得从根到所有的节点仅存在唯一的路径;当最佳路径故障时,自动打开部分阻塞端口,来实现线路备份的作用

        生成树在生成过程中,应该尽量的生成一棵星型结构,且最短路径树

存在算法

         802.1D      PVST PVST+(CISCO)      RSTP(802.1w)      MSTP(802.1S)

1、802.1D

        一个交换网络内仅存在一棵生成树实例

        交换机间使用BPDU—桥协议数据单元 – 交换机间沟通互动收发的数据

         配置BPDU  ——  只有根网桥可以发送,在交换网络初始状态时,所有交换机均定义本地为根网桥,进行BPDU的发送

        使得网络中所有交换机均收到其他设备的BPDU,之后基于数据中的参数进行比对,选举出根网桥;再所有非根网桥不再发送BPDU,而是仅接收和转发根网桥的BPDU

        周期2s发送,hold time 20s

TCN  ——  拓扑变更消息(也是BPDU):

        本地交换机链路故障后,STP重新收敛为了快速刷新全网所有交换机的MAC表将向本地所有STP接口发送TCN(标记位中的TCN位置1),邻居交换机收到TCN后标记为ACK位为回复,用于可靠传输消息,之后将TCN逐级转发到根网桥处,由根网桥回复TC消息来逐级回复到所有交换机

        使所有交换机临时将MAC表的老化时间修改为15s(默认的,转发延时)

选举--- 根网桥    根端口     指定端口   非指定端口(阻塞端口)

 【1】根网桥 —— 在一棵生成树实例中有且仅有一台交换机为root

BPDU中的 桥ID来决定

桥ID= 网桥优先级(0-65535公有) 默认32768 +  MAC地址(只有存在svi接口的交换机才拥有mac地址,若存在多个mac选数值最小)

        根网桥的选举   先比较优先级,小优;   若优先级相同,比较mac,数值小优

【2】根端口  ——  在每台非根网桥上,有且仅有一个接口;本地离根网桥最近的接口(最短、星型),接收来自根网桥的BPDU,转发用户的流量(该接口不阻塞)

        规则

                1、 比较从根网桥发出后,通过该接口进入时最小的cost值;

                2、入向cost值相同,比较该接口对端设备的BID,小优

                3、对端BID也相同,比较该接口对端设备的接口的PID;先优先级小,若优先级一致,编号小

                4、连对端PID也相同,比较本地PID,小优

PID=端口ID   接口优先级(0-240,步长16,默认128)      接口编号

【3】指定端口,在每一段存在STP的物理链路上有且仅有一个;转发来自根网桥的BPDU,同时可以转发用户流量(不阻塞);默认根网桥上所有接口为指定端口

    1、比较从根网桥发出后,通过该接口进入这段链路时的cost值最小(出向)

    2、若出向cost值相同,必须本地的BID,小优;

    3、本地BID相同,比较本地的PID;

    4、本地PID,相同,直接阻塞该端口

【4】非指定端口(阻塞端口)当以上所有角色全部选举完成后,剩余没有任何角色的接口为非指定;

         该接口逻辑阻塞,实际可以接收到信息,但不转发

接口状态

        down:

                没有BPDU收发,一旦可以进行BPDU收发进入下一状态

        侦听:

                强制15s;所有交换机进行BPDU收发,选举所有角色;接口角色为非指定端口直接进入阻塞状态;

              若为指定端口和根端口进入下一状态

        学习:

                强制15s; 指定端口和根端口学习所有接口连接设备的MAC地址,生成MAC表;之后进入下一状态

        转发:

                指端端口和根端口进入,可以转发用户报文

        阻塞:

                逻辑阻塞

注意:

        只有到接口进入到转发状态后,才能为用户转发数据报文,之前的30s不能转发任何数据

收敛时间

        初次收敛—30s =  15侦听+15s学习

结构变化

        存在直连检测

                本地存在阻塞端口,若其他端口断开,该阻塞端口马上进入15是侦听(选举);结果若为启用,那么将再进入15s学习---总30s

        没有直连检测

                本地不存在阻塞端口,若某个端口断开,将发送次优BPDU(以本地为根)给其他邻居交换机,其他交换机无视该数据,进行20s hold time计时,到时时阻塞接口进入15s侦听,15s学习=总50s

802.1D 缺点

        1、收敛慢

        2、链路利用率低

2、PVST  cisco私有

        基于VLAN的生成树协议

        在每个vlan内,存在一棵树,每个树的工作原理同802.1d一致;不同vlan的BPDU区别在于优先级;

        优先级=4096倍数+vlan id   人为仅可修改4096倍数备份,且只能修改为4096的整倍

        仅支持  trunk干道封装为ISL(cisco私有封装)

3、PVST +

        在PVST的基础,兼容802.1q的trunk封装;且设计了部分的加速;端口加速(进入层连接用户的接口)

           上行链路加速-针对直连检测     

        上行链路加速仅在接入层设备上配置,因为配置后,该交换机将自动加大本地的网桥优先级;

        在直连检测条件下阻塞接口将跳过30s,直接进入转发状态--上行链路加速

缺点

        1、收敛慢(加速不彻底)

        2、树多(仅cisco存在单独的芯片,友商无法负荷)

4、快速生成树

                cisco的RSTP   ---    基于vlan的快速生成树  - 一个vlan一棵树    pvst+的升级

                公有RSTP(802.1w) --- 整个交换网络一棵树                       802.1d的升级

快速原理     
  1. 取消了计时器,而是在一个状态工作完成后,直接进入下一状态
  2. 分段式同步,两台设备间逐级收敛;使用请求和同意标记;依赖标记位的第1和第6位
  3. BPDU的保活为6s;hello time 2s;
  4. 将端口加速(边缘接口)、上行链路加速、骨干加速集成了
  5. 兼容802.1d和PVST,但802.1d和PVST没有使用标记位中的第1-6位,故不能快速收敛;因此如果网络中有一台设备不支持快速收敛,那么其他开启快速收敛的设备也不能快速

      当tcn消息出现时,不需要等待根网桥的BPDU,就可以刷新本地的cam表  

注意:

        接口默认为半双工时,即便允许RSTP,依然基于慢速的802.1D算法来收敛

边缘接口

        用于连接PC的接口,一旦被设定为边缘接口;将不再进行BPDU的发送且不进行STP的收敛,直接为转发状态

        但若该接口收到了对端的BPDU,将失去边缘特性,重新正常收敛

5、MSTP/MST/802.1S

       华为设备默认使用该协议

        继承了快速生成树的基础;  将多个vlan放置于一个组内,基于每个组一棵生成树 

        不同组间的BPDU中优先级= 4096倍数+组号

        默认存在组0,且所有vlan默认处于该组;优先级= 32768+0

注意:

        若将创建某个组,但该组内的vlan,在本交换机上没有创建,同时没有为该vlan服务的接口;该组将没有任何信息;整个交换网络中所有设备的分组信息必须完全一致

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TCP特点UDP编程

目录 1、tcp协议和udp协议 2、多线程并发和多进程并发: (1)多进程并发服务端 (2)多进程并发客户端: 3、tcp: 4、粘包 5、UDP协议编程流程 (1)服务器端: (2)客户端: 6、tcp状…

JavaEE初阶:Java线程的状态

目录 获取当前线程引用 休眠当前线程 线程的状态 1.NEW 2.TERMINATED 3.RUNNABLE 4.WAITING 5.TIMED_WAITING 6.BLOCKED 多线程的意义 单线程 多线程 获取当前线程引用 public static Thread currentThread(); 这个方法返回当前线程的引用。但是我…

WSL2 Ubuntu20.04 配置 CUDA

前言 本文主要讲解如何在 Widnows 11 环境下的 WSL2(Ubuntu20.04)配置 CUDA 来启用 GPU 加速(本文默认您已经在 Windows 上安装完成 Nvidia CUDA) 配置流程 检查驱动 打开 GeForce Experience 检查驱动程序的情况,…

基于 BlockQueue(阻塞队列) 的 生产者消费者模型

文章目录 阻塞队列(BlockQueue)介绍生产者消费者模型 介绍代码实现lockGuard.hpp()Task.hpp(任务类)BlockQueue.hpp(阻塞队列)conProd.cc(生产者消费者模型 主进程&#…

从来不懂K8s的人10分钟内将应用跑在了K8s中

大家可能都听说过 K8s 或者 docker ,可能有容器编排的概念,知道这会提高运维效率,但是由于上手难度高迟迟没有学习它。 今天我以自己的实际经历教大家将自己的应用在10分钟内部署到k8s中,你不需要懂任何的 docker 命令和 k8s 命令…

LinkedList

LinkedList的模拟实现(底层是一个双向链表)LinkedList使用 LinkedList的模拟实现(底层是一个双向链表) 无头双向链表:有两个指针;一个指向前一个节点的地址;一个指向后一个节点的地址。 节点定…

STM32单片机实现Bootloader跳转的关键步骤

感谢关注! 本期话题 现在越来越多的嵌入式设备支持远程自动升级,不需要再借助下载器。这样对于设备的维护非常方便。 当然若使设备支持远程升级,需要编写支持升级的程序代码,可以称之为 BootLoader。 也就是说,将设…

【二叉树构建与遍历3】先序遍历+后序遍历构建一个满二叉树并输出中序遍历 C++实现

注意:根据先序遍历与后序遍历只有在满二叉树的情况下才能确定一个唯一的树。这里介绍的是根据先序遍历后序遍历构建一个满二叉树并输出中序遍历顺序。 思路: 先来一个例子: 先序遍历序列为:FDXEABG 后序遍历序列为:…

股票委托接口的部分源码分析(一)

对于一些股票委托接口的源码分析需要具体指定的交易系统可能有不同的接口实现。以下是对一个常见的股票委托接口实现的源码分析示例: import requestsdef place_order(symbol, price, quantity, side): url https://example.com/api/place_order payload {…

gRPC 客户端调用服务端需要连接池吗?

发现的问题 在微服务开发中,gRPC 的应用绝对少不了,一般情况下,内部微服务交互,通常是使用 RPC 进行通信,如果是外部通信的话,会提供 https 接口文档 对于 gRPC 的基本使用可以查看文章 gRPC介绍 对于 g…

ClickHouse(二十三):Java Spark读写ClickHouse API

进入正文前,感谢宝子们订阅专题、点赞、评论、收藏!关注IT贫道,获取高质量博客内容! 🏡个人主页:含各种IT体系技术,IT贫道_Apache Doris,大数据OLAP体系技术栈,Kerberos安全认证-CSDN博客 &…

vue开发环境搭建(WebStorm)

一、安装Node.js,搭建Vue环境 1、访问Node.js官网(https://nodejs.org/en/download/)进行安装包下载。 2、下载成功之后运行安装程序,进行安装。 如果是用安装程序进行安装,在安装过程中会自动进行Nodejs环境变量的配置…

最新两年工作经验总结

最新两年工作经验总结 前言URP的使用1:如何开启URP1、老项目升级为URP2、创建新项目时选择URP创建 2:URP阴影的设置 PolyBrush的使用(地图编辑插件)制作山峰or低谷边缘柔化雨刷上色制造场景中的物体贴图地形创建容易踩坑的点ProBu…

springboot大文件上传、分片上传、断点续传、秒传的实现

对于大文件的处理,无论是用户端还是服务端,如果一次性进行读取发送、接收都是不可取,很容易导致内存问题。所以对于大文件上传,采用切块分段上传,从上传的效率来看,利用多线程并发上传能够达到最大效率。 …

示例1:FreeRTOS移植详解_基于HAL库工程

1、开发环境 (1)Keil MDK: V5.38.0.0 (2)STM32CubeMX: V6.8.1 (3)MCU: STM32F103C8(F1系列软仿真最方便) (4)ARM编译器:V5(使用V6编译会报错) 2、移植准备工作 (1)用于移植FreeRTOS的基础工程。 时钟已配置好串口已配置好printf已经重定向到串口1 (2)FreeRT…

《YOLO小目标检测》专栏介绍 CSDN独家改进创新实战专栏目录

💡💡💡Yolo小目标检测,独家首发创新(原创),适用于Yolov5、Yolov7、Yolov8等各个Yolo系列,专栏文章提供每一步步骤和源码,带你轻松实现小目标检测涨点 💡&…

【二分查找篇】速刷牛客TOP101 高效刷题指南

文章目录 17、BM17 二分查找-I18、BM18 二维数组中的查找19、BM19 寻找峰值20、BM20 数组中的逆序对21、BM21 旋转数组的最小数字22、BM22 比较版本号23、BM23 二叉树的前序遍历 17、BM17 二分查找-I 思路步骤: step 1:从数组首尾开始,每次取…

wustojc日期格式变化

#include <stdio.h> int main() {char a[10];for(int i0;i<10;i){//用一个耍聪明的方法&#xff0c;全部用数组存储&#xff1b;面向结果编程a[0]getchar();}printf("%c%c%c%c%c%c%c%c%c%c",a[6],a[7],a[8],a[9],a[2],a[0],a[1],a[5],a[3],a[4]);return 0;}…

什么是跳跃表 ? 说一说跳跃表的查询和新增流程 ?

1.什么是跳跃表&#xff08;Skip List&#xff09; 跳跃表是 ZSet 有序列表底层的一种实现&#xff0c;也成为跳表。它通过添加多层链表的方式&#xff0c;用于在有序集合中进行高效的查找操作。 简单跳跃表的结构图&#xff1a; 从图中可以看出跳跃表有这些特征&#xff1a; …

Nginx-URLRewrite伪静态

URLRwrite是指将真实地址隐藏&#xff0c;用户访问是通过伪地址进行访问&#xff0c;这样可以隐藏URL中的传参等等 URLwrite演示&#xff0c;浏览器输入伪URL&#xff0c;回车会跳转到真实URL Rewrite匹配规则 redirect是指当请求伪装地址后&#xff0c;页面会直接跳转到真实…