热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

STP知识点汇总

文章目录定义存在算法802.1DPVSTPVST快速生成树MSTPMST802.1S生成树协议企业网三层架构—冗余—线路冗余—二层桥接环路导致问题:广播风暴M


文章目录

        • 定义
        • 存在算法
          • 802.1D
          • PVST
          • PVST +
          • 快速生成树
          • MSTP/MST/802.1S

生成树协议
企业网三层架构 —> 冗余 —> 线路冗余 —> 二层桥接环路
导致问题:


  1. 广播风暴
  2. MAC地址表翻滚
  3. 同一数据帧的重复拷贝
  4. 以上3个条件最终导致设备工作过载,导致重启保护

定义

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


存在算法

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


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,转发用户的流量(该接口不阻塞)

规则:


  • 比较从根网桥发出后,通过该接口进入时最小的cost值;
  • 入向cost值相同,比较该接口对端设备的BID,小优
  • 对端BID也相同,比较该接口对端设备的接口的PID;先优先级小,若优先级一致,编号小
  • 连对端PID也相同,比较本地PID,小优;

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

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


  1. 比较从根网桥发出后,通过该接口进入这段链路时的cost值最小(出向)
  2. 若出向cost值相同,必须本地的BID,小优;
  3. 本地BID相同,比较本地的PID;
  4. 本地PID,相同,直接阻塞该端口;
    【4】非指定端口(阻塞端口)当以上所有角色全部选举完成后,剩余没有任何角色的接口为非指定;
    该接口逻辑阻塞,实际可以接收到信息,但不转发;

cost值:不同带宽 存在不同cost


802.1d标准802.1T标准
10M = 100
100M=19100M=200000
1000M=41000M= 20000
10000M=2
100000M=1

[SWA]stp pathcost-standard ? 默认华为使用802.1t标准
dot1d-1998 IEEE 802.1D-1998
dot1t IEEE 802.1T
legacy Legacy

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

接口状态:


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

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

收敛时间:
初次收敛为30s = 15侦听+15s学习
结构变化:


  • 存在直连检测:本地存在阻塞端口,若其他端口断开,该阻塞端口马上进入15是侦听(选举);结果若为启用,那么将再进入15s学习—总30s
  • 没有直连检测:本地不存在阻塞端口,若某个端口断开,将发送次优BPDU(以本地为根)给其他邻居交换机,其他交换机无视该数据,进行20s hold time计时,到时时阻塞接口进入15s侦听,15s学习=总50s

802.1D 缺点:


  • 收敛慢
  • 链路利用率低

802.1配置命令:

[sw1]stp mode stp 修改为802.1d算法,当下华为默认为MSTP;
[sw1]stp priority 4096 修改网桥优先级[sw1-GigabitEthernet0/0/1]stp cost ? 修改接口cost值INTEGER<1-200000000> Port path cost[sw1-GigabitEthernet0/0/1]stp port priority ? 修改接口优先级INTEGER<0-240> Port priority, in steps of 16

PVST

cisco私有 基于vlan的生成树协议
在每个vlan内&#xff0c;存在一棵树&#xff0c;每个树的工作原理同802.1d一致&#xff1b;不同vlan的BPDU区别在于优先级&#xff1b;
优先级&#61;4096倍数&#43;vlan id 人为仅可修改4096倍数备份&#xff0c;且只能修改为4096的整倍
仅支持 trunk干道封装为ISL&#xff08;cisco私有封装&#xff09;


PVST &#43;

在PVST的基础&#xff0c;兼容802.1q的trunk封装&#xff1b;且设计了部分的加速&#xff1b;


  • 端口加速&#xff08;进入层连接用户的接口&#xff09;
  • 上行链路加速-针对直连检测
  • 骨干加速—针对次优BPDU

缺点&#xff1a;1、收敛慢&#xff08;加速不彻底&#xff09; 2、树多&#xff08;仅cisco存在单独的芯片&#xff0c;友商无法负荷&#xff09;


快速生成树

cisco的RSTP — 基于vlan的快速生成树 — 一个vlan一棵树 pvst&#43;的升级
公有RSTP&#xff08;802.1w&#xff09; —> 整个交换网络一棵树 802.1d的升级
快速的原理&#xff1a;


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

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

[sw1]stp mode rstp
边缘接口---用于连接PC的接口&#xff0c;一旦被设定为边缘接口&#xff1b;将不再进行BPDU的发送&#xff0c;且不进行STP的收敛&#xff0c;直接为转发状态&#xff1b; 但若该接口收到了对端的BPDU&#xff0c;将失去边缘特性&#xff0c;重新正常收敛&#xff1b;
[sw1]interface GigabitEthernet 0/0/1
[sw1-GigabitEthernet0/0/1]stp edged-port enable[sw1]stp priority ? 修改网桥优先级INTEGER<0-61440> Bridge priority, in steps of 4096 [sw1]stp root ? 快速定义根网桥角色primary Primary root switchsecondary Secondary root switch[sw1-GigabitEthernet0/0/1]stp port priority ? 修改接口优先级INTEGER<0-240> Port priority, in steps of 16[sw1-GigabitEthernet0/0/1]stp cost ? 修改接口costINTEGER<1-200000000> Port path cost

MSTP/MST/802.1S

华为设备默认使用该协议
继承了快速生成树的基础&#xff1b; 将多个vlan放置于一个组内&#xff0c;基于每个组一棵生成树&#xff1b;
不同组间的BPDU中优先级&#61; 4096倍数&#43;组号

[r1]stp mode mstp
默认存在组0&#xff0c;且所有vlan默认处于该组&#xff1b;优先级&#61; 32768&#43;0
分组
[sw1]stp enable
[sw1]stp region-configuration
[sw1-mst-region]region-name a 所有设备应在一个组内
[sw1-mst-region]instance 1 vlan 1 to 5
[sw1-mst-region]instance 2 vlan 6 to 10
[sw1-mst-region]active region-configuration 激活当前配置&#xff08;必须配置该指令&#xff09;

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

定义本地为组1 的主根&#xff0c;组2 的备份根
stp instance 1 root primary 优先级修改为0
stp instance 2 root secondary 优先级修改为4096[sw1]stp instance 1 priority ?INTEGER<0-61440> Bridge priority, in steps of 4096[sw1]interface GigabitEthernet 0/0/1
[sw1-GigabitEthernet0/0/1]stp instance 1 cost ?INTEGER<1-200000000> Port path cost[sw1-GigabitEthernet0/0/1]stp instance 1 port priority ?INTEGER<0-240> Port priority, in steps of 16

推荐阅读
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • HSRP热备份路由器协议的应用及配置
    本文介绍了HSRP热备份路由器协议的应用及配置方法,包括设计目标、工作原理、配置命令等。通过HSRP协议,可以实现在主动路由器故障时自动切换到备份路由器,保证网络连通性。此外,还介绍了R1和R2路由器的配置方法以及Sw1和Sw2交换机的配置方法,最后还介绍了测试连通性和路由追踪的方法。 ... [详细]
  • 提升Python编程效率的十点建议
    本文介绍了提升Python编程效率的十点建议,包括不使用分号、选择合适的代码编辑器、遵循Python代码规范等。这些建议可以帮助开发者节省时间,提高编程效率。同时,还提供了相关参考链接供读者深入学习。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 开发笔记:计网局域网:NAT 是如何工作的?
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了计网-局域网:NAT是如何工作的?相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 本文介绍了在MFC下利用C++和MFC的特性动态创建窗口的方法,包括继承现有的MFC类并加以改造、插入工具栏和状态栏对象的声明等。同时还提到了窗口销毁的处理方法。本文详细介绍了实现方法并给出了相关注意事项。 ... [详细]
  • 上图是InnoDB存储引擎的结构。1、缓冲池InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。因此可以看作是基于磁盘的数据库系统。在数据库系统中,由于CPU速度 ... [详细]
  • HashMap的扩容知识详解
    本文详细介绍了HashMap的扩容知识,包括扩容的概述、扩容条件以及1.7版本中的扩容方法。通过学习本文,读者可以全面了解HashMap的扩容机制,提升对HashMap的理解和应用能力。 ... [详细]
author-avatar
手机用户2502939545
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有