生成树协议 — STP

news2024/10/1 21:43:28

 

目录

一、环路的出现

1、广播风暴: 

 2、MAC地址表翻滚:

二、生成树

1、定义:

2、生成树使用的算法: 

三、802.1D

        1、BPDU:

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

3、部分名词:

4、不同端口的选举规则—生成树的过程:

1.根网桥选举规则:

2.根端口选举规则:

3.指定端口选举规则:

4.非指定端口选举规则:

5、端口状态: 

6、cost值:

7、收敛时间:

8、802.1D 缺点:

四、PVST

1、PVST的优势:        

2、工作方式: 

五、PVST + :

1、加速种类 :

2、PVST+仍然存在的缺点:

六、快速生成树(RSTP / 8032.1w)

1、RSTP:

2、802.1w:

3、快速的原理:

4、端口角色:

5、P/A机制

6、干涉快速生成树工作:

1.边缘接口:

2.修改网桥优先级:

3.快速定义根网桥角色:

4.修改接口优先级:

5.修改接口开销(cost):

七、MSTP(MST / 802.1S)

1、多实例生成树协议(MSTP) 

2、分组配置示例:

3、定义本地为组1 的主根,组2 的备份根:

4、修改优先级:

5、修改开销:

6、修改接口优先级:


一、环路的出现

在常见的内网中为了保持网络的稳定性和可靠性通常会有设备之间进行冗余 ,但是也会导致一些问题:

  1. 广播风暴
  2. MAC地址表翻滚
  3. 同一数据帧的重复拷贝

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

1、广播风暴: 

         3台交换机SWA、SWB、SWC以下图的方式连接在一起,假设主机A想要给主机B发送数据,首先会发送一个ARP请求来获取主机B的MAC地址。但是由于ARP的Request包属于一个广播帧,当SWB接收到主机A发送来的广播帧时,会将该广播帧发送给所有的端口;SWA收到SWB发来的广播帧时,同样也会发送给所有端口;以此类推。这时,在SWA、SWB、SWC中就会循环往复地收发广播帧,耗费交换机资源,导致业务瘫痪。

 2、MAC地址表翻滚:

        环路除了会带来广播风暴的问题,还会带来MAC地址表的翻滚。当SWB第一次收到主机A发送过来的广播帧时,源MAC地址为:00-05-06-07-08-AA,源端口为G0/0/3。由于广播帧在三台交换机中循环往复的收发,当SWC将广播帧发给SWB时,SWB收到的广播帧的MAC地址依旧没变,即:00-05-06-07-08-AA。但是此时的源端口却变成了SWC的G0/0/2端口。这就是MAC地址翻滚。

二、生成树

1、定义:

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

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

2、生成树使用的算法: 

  • 802.1D     
  • PVST       (cisco私有)     
  • PVST+     (cisco私有)     
  • RSTP(802.1w)     
  • MSTP(802.1S)

三、802.1D

  • 802.1D:生成树协议最开始的版本。
  • 封装格式:802.3 | LLC | STP
  • 目的组播MAC地址:01-80-C2-00-00-00     

1、BPDU:

        交换机间使用 桥协议数据单元(BPDU) 进行 交换机间沟通互动收发的数据。

  • Protocol-id:stp协议
  • Protocol-version id:stp的版本
  • Bpdu-type:bpdu的类型,配置bpdu还是TCNbpdu(拓扑变化通告)
  • Falgs:在STP中使用了2bit,分为TCA(拓扑变化确认),TC(拓扑变更)
  • Root id:根桥ID
  • Cost of path:根路径开销
  • Bridge id:桥ID
  • Port id:端口ID
  • Message age:消息时间,每经过一台交换机,加1。所以网络不是很大。
  • Max age:老化时间,20s。
  • Hello time:BPDU的发送周期2s。
  • Forwad delay:转发延迟,配置BPDU传播到全网最大延迟15s

        开启STP后:配置BPDU 只有根网桥可以发送。

  •         在交换网络初始状态时,所有交换机均定义本地为根网桥,进行BPDU的发送;使得网络中所有交换机均收到其他设备的BPDU,之后基于数据中的参数进行比对,选举出根网桥;所有非根网桥不再发送BPDU,而是仅接收和转发根网桥的BPDU;
    •         发送周期hello time 2s;老化时间 20s;

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

  •   本地交换机链路故障后STP重新收敛。
  • 为了快速刷新全网所有交换机的MAC表,将向本地所有STP接口发送TCN(标记位中的TCN位  置1)。
  • 邻居交换机收到TCN后,先标记为ACK位为回复,用于可靠传输消息;之后将TCN逐级转发到根网桥处,由根网桥回复TC消息来逐级回复到所有交换机。
  • 使所有交换机临时将MAC表的老化时间修改为15s(默认的,转发延时)

3、部分名词:

序号:名称:释义:
1根网桥在一棵生成树实例中,有且仅有一台交换机为root(根网桥)。
2根端口

在每台根网桥上,有且仅有一个接口。

交换机本地离根网桥最近的接口(满足:最短、星型),接收来自根网桥的BPDU,并转发用户的流量(该接口不阻塞)。

3指定端口

在每一段存在STP的物理链路上,有且仅有一个;转发来自根网桥的BPDU,同时可以转发用户流量(不阻塞)。

默认根网桥上所有接口为指定端口。

4非指定端口

又称:阻塞端口

当以上所有角色全部选举完成后,剩余没有任何角色的接口为非指定接口。

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

4、不同端口的选举规则—生成树的过程:

1.根网桥选举规则:

  •  根网桥的选举先比较优先级——小优。网桥优先级(0-65535公有) 默认32768
  • 若优先级相同,比较MAC——数值小优。MAC地址(只有存在svi接口的交换机才拥有mac地址,若存在多个mac选数值最小)

        桥ID(BID)= 网桥优先级 + MAC地址

2.根端口选举规则:

  1. 比较从根网桥发出后,通过交换机改接口进入时的最小cost值 。
  2. 若入向cost值相同,则比较该接口对端设备的BID——小优。
  3. 若对端BID也相同,则比较该接口端设备的接口的PID。先优级小优;若优先级一致,编号小优。
  4. 若连对端PID也相同,则比较本地PID——小优。 

从上而下匹配,优先比较最开始的条件,若匹配则不进行后面的比较 

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

3.指定端口选举规则:

  1. 默认根网桥上所有接口为指定端口。
  2. 比较从根网桥发出后,通过该接口进入这段链路时的cost值最小优(出向)。
  3. 若出向cost值相同,则比较本地链路两端的BID——小优。
  4. 若本地链路两端的BID相同,则比较本地链路两端的的PID。
  5. 若本地链路两端的PID相同,直接阻塞该端口。

4.非指定端口选举规则:

  •  当以上所有角色全部选举完成后,剩余没有任何角色的接口为非指定端口。

5、端口状态: 

  •  down:没有BPDU收发,一旦可以进行BPDU收发进入下一状态。
  • 侦听:强制15s。所有交换机进行BPDU收发,选举所有角色。接口角色为非指定端口直接进入阻塞状态;若为指定端口和根端口进入下一状态。
  • 学习:强制15s。指定端口和根端口学习所有接口连接设备的MAC地址,生成MAC表。之后进入下一状态。
  • 转发:指端端口和根端口进入,可以转发用户报文。
  • 阻塞:逻辑阻塞。

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

华为端口状态:

6、cost值:

  •  不同带宽 存在不同cost

[SWA]stp pathcost-standard ?    默认华为使用802.1t标准

  dot1d-1998  IEEE 802.1D-1998

  dot1t       IEEE 802.1T

  legacy      Legacy

生成协议中,至少应该将根网桥干涉到汇聚层处

7、收敛时间:

  • 初次收敛:

30s =  15侦听+15s学习

  • 结构变化:

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

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

8、802.1D 缺点:

  1.  收敛慢
  2. 链路利用率低

四、PVST

  •  PVST是cisco私有协议——基于vlan的生成树协议。

1、PVST的优势:        

        优于802.1D的是能够一定程度上的改善链路利用率底的问题。 

2、工作方式: 

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

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

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

五、PVST + :

  •  PVST同样是Cisco的私有协议,在PVST的基础上,兼容802.1q的trunk封装,且设计了部分的加速

1、加速种类 :

  1.  端口加速(进入层连接用户的接口)     
  2. 上行链路加速:针对直连检测      
  3. 骨干加速:针对次优BPDU

上行链路加速:仅在接入层设备上配置,因为配置后,该交换机将自动加大本地的网桥优先级;在直连检测条件下阻塞接口将跳过30s,直接进入转发状态--上行链路加速

骨干加速:所有交换机均可配置,针对接收到次优BPDU的阻塞端口可以跳过20s的老化时间。

2、PVST+仍然存在的缺点:

  1.  收敛慢(加速不彻底)
  2. 树多(仅cisco存在单独的芯片,友商无法负荷)    

六、快速生成树(RSTP / 8032.1w)

1、RSTP:

  •  RSTP是cisco的私有协议。  基于vlan的快速生成树—— 一个vlan一棵树   
  • pvst+的升级版

2、802.1w:

  •  802.1w:即公有的RSTP。基于整个交换网络一棵树。 
  • 802.1d的升级

3、快速的原理:

  1.  取消了计时器。在一个状态工作完成后,直接进入下一状态。
  2. 分段式同步,两台设备间逐级收敛,使用请求和同意标记,依赖标记位的第1和第6位。
  3. BPDU的保活(老化)为 6s(=3*hello time);hello time 2s;
  4. 将端口加速(边缘接口)、上行链路加速、骨干加速 进行了集成。
  5. 兼容802.1d和PVST,但802.1d和PVST没有使用标记位中的第1-6位,故不能快速收敛。因此如果网络中有一台设备不支持快速收敛,那么其他开启快速收敛的设备也不能快速。
  6. 当tcn消息出现时,不需要等待根网桥的BPDU,就可以刷新本地的cam表.

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

4、端口角色:

  • 保留项:根端口、指定端口
  • 增加项:预备端口、备份端口
  • 预备端口 为根端口的备份,实现快速切换。
  • 备份端口 为指定端口的备份,需要P/A机制进行切换。同时不转发数据(与阻塞端口相同)

5、P/A机制

  • 涉及Flags中的Proposal位和Agreement位。
  • 作用:使指定端口快速进入forwading状态.
  1. 当一个接口成为指定接口后,交换机发送RST-BPDU中其中标志位P位置1,Role位为11,向外发送。
  2. 其他交换机收到收到proposal报文,阻塞非边缘端口之外的所有非边缘端口。并且发送RST BPDU中的标志位 Agreement位置1。
  3. 交换机收到标志位中的同意位置1的BPDU之后,立即进入转发状态。
  4. 当一个端口被选举成为指定端口之后,在STP中,该端口至少要等待一个Forward Delay(Learning)时间才会迁移到Forwarding状态。而在RSTP中,此端口会先进入Discarding状态,再通过Proposal/Agreement机制快速进入Forward状态。这种机制必须在点到点全双工链路上使用。

        在PA机制选举时,非边缘指定端口要进入阻塞状态,防止临时环路。因为PA机制选举完成之后会立即进行转发状态,如果其他交换机的原来是指定端口、对端是根端口时为转发状态还没来得及切换到阻塞状态,会造成临时环路。

6、干涉快速生成树工作:

1.边缘接口:

  • 用于连接PC的接口
  • 一旦被设定为边缘接口将不再进行BPDU的发送,且不进行STP的收敛,直接为转发状态。
  •  但若该接口收到了对端的BPDU,将失去边缘特性,重新正常收敛。
[sw1]interface GigabitEthernet 0/0/1
[sw1-GigabitEthernet0/0/1]stp edged-port enable    #定义为边缘端口

2.修改网桥优先级:

[sw1]stp priority ? 
  INTEGER<0-61440>  Bridge priority, in steps of 4096

3.快速定义根网桥角色:

[sw1]stp root ? 
  primary    Primary root switch    #定义为根网桥
  secondary  Secondary root switch    #定义为备份根网桥

4.修改接口优先级:

[sw1-GigabitEthernet0/0/1]stp port  priority ?  
  INTEGER<0-240>  Port priority, in steps of 16

5.修改接口开销(cost):

[sw1-GigabitEthernet0/0/1]stp cost ?
  INTEGER<1-200000000>  Port path cost

七、MSTP(MST / 802.1S)

1、多实例生成树协议(MSTP) 

  •  华为设备默认使用该协议
  • 继承了快速生成树的基础,基于组的生成树,将多个vlan放置于一个组内形成一棵生成树。
  • 默认存在组0,且所有vlan默认处于该组。优先级= 32768 + 0 

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

2、分组配置示例:

[sw1]stp enable
[sw1]stp region-configuration
[sw1-mst-region]region-name a    #所有设备应在一个组内
[sw1-mst-region]instance 1 vlan 1 to 5    #组一划入vlan 1 到 vlan
5
[sw1-mst-region]instance 2 vlan 6 to 10
[sw1-mst-region]active region-configuration     #激活当前配置(必须配置该指令)

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

3、定义本地为组1 的主根,组2 的备份根:

stp instance 1 root primary      #优先级修改为0(定义为组1的根)
stp instance 2 root secondary    #优先级修改为4096(定义为组2的备份根)

4、修改优先级:

[sw1]stp instance  1  priority ?
  INTEGER<0-61440>  Bridge priority, in steps of 4096

5、修改开销:

[sw1]interface GigabitEthernet 0/0/1
[sw1-GigabitEthernet0/0/1]stp instance 1 cost ?
  INTEGER<1-200000000>  Port path cost

6、修改接口优先级:

[sw1-GigabitEthernet0/0/1]stp instance 1 port priority ?
  INTEGER<0-240>  Port priority, in steps of 16

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

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

相关文章

【Python小游戏】某程序员将套圈游戏玩儿到了巅峰,好嗨哟~Pygame代码版《牛牛套圈》已上线,大人的套圈游戏太嗨了,小孩勿进。

前言 世上选择那么多。 关注栗子同学会是您最明智的选择哦。 所有文章完整的素材源码都在&#x1f447;&#x1f447; 粉丝白嫖源码福利&#xff0c;请移步至CSDN社区或文末公众hao即可免费。 “幸运牛牛套圈圈”套住欢乐&#xff0c;圈住幸福&#xff0c;等你来挑战&#xf…

用OpeAI API打造ChatGPT桌面端应用

用OpeAI API打造ChatGPT桌面端应用 自从《如何用ChatGPT高效完成工作》这篇文章火了之后&#xff0c;我在公司内部分享了一下”摸鱼“的先进经验&#xff0c;激发起广大同事一起”摸鱼“的热情。但是注册ChatGPT账号非常麻烦&#xff0c;既要Science上网&#xff0c;又要海外手…

Spark环境搭建

文章目录Spark 概述Spark 发展历史使用现状官网介绍流行原因组成模块Spark环境搭建-Local模式(本地模式)Spark环境搭建-Standalone(独立集群)Spark环境搭建-Standalone-HA(高可用)Spark环境搭建-Spark-On-Yarn两种模式Spark 概述 Spark 发展历史 2009年诞生2014年成为Apache顶…

Java笔记-线程中断

线程的中断 1.应用场景&#xff1a; 假设从网络下载一个100M的文件&#xff0c;如果网速很慢&#xff0c;用户等得不耐烦&#xff0c;就可能在下载过程中点“取消”&#xff0c;这时&#xff0c;程序就需要中断下载线程的执行。 2.常用中断线程的方法&#xff1a; 1.使用标…

Canvas鼠标滚轮缩放以及画布拖动(图文并茂版)

Canvas鼠标滚轮缩放以及画布拖动 本文会带大家认识Canvas中常用的坐标变换方法 translate 和 scale&#xff0c;并结合这两个方法&#xff0c;实现鼠标滚轮缩放以及画布拖动功能。 Canvas的坐标变换 Canvas 绘图的缩放以及画布拖动主要通过 CanvasRenderingContext2D 提供的 …

C++设计模式(13)——装饰模式

亦称&#xff1a; 装饰者模式、装饰器模式、Wrapper、Decorator 意图 装饰模式是一种结构型设计模式&#xff0c; 允许你通过将对象放入包含行为的特殊封装对象中来为原对象绑定新的行为。 问题 假设你正在开发一个提供通知功能的库&#xff0c; 其他程序可使用它向用户发…

注册ChatGPT的辛酸血泪史,不能算教程的教程

注册ChatGPT的血泪史 2月份了&#xff0c;改论文降重了&#xff0c;所以想搞个ChatGPT玩玩&#xff0c;本以为有渠道能顺序上车&#xff0c;但是看了很多教程&#xff0c;也进了很多交流群&#xff0c;都喵的(要不是卖号&#xff0c;租体验&#xff0c;liar)&#xff0c;所以自…

java ssm高校教材管理平台 idea maven

设计并且实现一个基于JSP技术的高校教材管理平台的设计与实现。采用MYSQL为数据库开发平台&#xff0c;SSM框架&#xff0c;Tomcat网络信息服务作为应用服务器。高校教材管理平台的设计与实现的功能已基本实现&#xff0c;主要学生、教材管理、学习教材、教材入库、教材领取、缴…

C语言 大数加法 大数乘法

最近刷题&#xff0c;总遇到大数加法&#xff08;浮点数&#xff09;和乘法问题(阶乘)&#xff0c;总结一下思路。 大数乘法主要思想&#xff1a;编程实现竖式乘法&#xff08;小学时候学的列竖式计算乘法&#xff09;创建一个很大的数组&#xff0c;用于存储大数的每一位。&am…

Android Q WiFi 代码框架

同学,别退出呀,我可是全网最牛逼的 WIFI/BT/GPS/NFC分析博主,我写了上百篇文章,请点击下面了解本专栏,进入本博主主页看看再走呗,一定不会让你后悔的,记得一定要去看主页置顶文章哦。 1 wifi 架构图 备注:在Android 9.0中,WiFi的状态处理在WifiStateMachine中进行,到…

c语言数据结构-图的遍历

(创作不易&#xff0c;感谢有你&#xff0c;你的支持&#xff0c;就是我前行的最大动力&#xff0c;如果看完对你有帮助&#xff0c;请留下您的足迹&#xff09; 目录 定义&#xff1a; 两种遍历方法&#xff1a; 深度优先搜索&#xff08;DFS&#xff09;&#xff1a; …

ElasticJob-Lite架构篇 - 认知分布式任务调度ElasticJob-Lite

前言 本文基于 ElasticJob-Lite 3.x 版本展开分析。 如果 Quartz 集群中有多个服务端节点&#xff0c;任务决定在哪个服务端节点上执行的呢&#xff1f; Quartz 采用随机负载&#xff0c;通过 DB 抢占下一个即将触发的 Trigger 绑定的任务的执行权限。 在 Quartz 的基础上&…

从0到1一步一步玩转openEuler--10 openEuler基础配置-设置kdump

10 openEuler基础配置-设置kdump 文章目录10 openEuler基础配置-设置kdump10.1 设置kdump10.1.1 设置kdump预留内存10.1.1.1 预留内存参数格式10.1.2 预留内存推荐值10.1.3 禁用网络相关驱动10.1 设置kdump 本节介绍如何设置kdump预留内存及修改kdump配置文件参数。 10.1.1 设…

写python爬虫,你永远绕不过去代理问题

如果你想要从事 Python 爬虫相关岗位&#xff0c;那你一定会接触到代理问题&#xff0c;随之而来的就是下面 5 大代理知识点。 什么是代理&#xff1a;代理是网络中间人&#xff08;中间商赚插件&#xff09;&#xff0c;它代表用户发送网络请求&#xff0c;隐藏用户的真实身份…

JDY-31蓝牙模块使用指南

前言 本来是想买个hc-05&#xff0c;这种非常常用的模块&#xff0c;但是在优信电子买的时候&#xff0c;说有个可以替代的&#xff0c;没注意看&#xff0c;买回来折腾半天。 这个模块是从机模块&#xff0c;蓝牙模块分为主机从机和主从一体的&#xff0c;主机与从机的区别就…

【安全】nginx反向代理+负载均衡上传webshel

Nginx负载均衡下上传webshell 什么是反向代理&#xff1f; 正向代理就是代替客户端进行各种服务的访问以及获取&#xff1b;那么反向代理自然就是代替服务器进行事务处理&#xff0c;就是此时的代理服务器负责将用户的各项请求做一个汇总、分类&#xff0c;将其分发到不同的服务…

网络抓包方式复现Tomcat- AJP协议文件读取/命令执行漏洞(CVE-2020-1938 / CNVD-2020-10487)

目录 测试是否安装成功​编辑 基础简介 Tomcat Connector(连接器) ​编辑Servlet(服务程序) Tomcat内部处理请求流程 Tomcat加载和处理jsp的流程图 抓包复现 需要将下图中抓取到的数据包修改一下 替换成二进制数据的形式&#xff1a; python版替换代码&#xff1a; 运…

WordPress网站日主题Ri主题RiProV2主题开启了验证码登录但是验证码配置不对结果退出登录后进不去管理端了

背景 WordPress网站日主题Ri主题RiProV2主题开启了验证码登录但是验证码配置不对结果退出登录后进不去管理端了;开启了腾讯云验证码防火墙但APPID,APPSecret没配置,结果在退出登录后,由于验证码验证失败管理端进不去了 提示如下:

自定义软件帮助文档(qt assistant实现)

网上搜了一下&#xff0c;软件的帮助文档&#xff0c;三个都可以&#xff1a;https://github.com/zealdocs/zeal&#xff0c;https://zealdocs.org/&#xff0c;看看这个博客说的 https://blog.csdn.net/libaineu2004/article/details/125028913&#xff0c;这个也是开源的&…

神经网络实战--使用迁移学习完成猫狗分类

前言&#xff1a; Hello大家好&#xff0c;我是Dream。 今天来学习一下如何使用基于tensorflow和keras的迁移学习完成猫狗分类&#xff0c;欢迎大家一起前来探讨学习~ 本文目录&#xff1a;一、加载数据集1.调用库函数2.加载数据集3.数据集管理二、猫狗数据集介绍1.猫狗数据集介…