STP协议树作用

为了提高网络可靠性,交换网络中通常会使用冗余链路。

然而,冗余链路会给交换网络带来环路风险

并导致广播风暴以及MAC地址表不稳定等问题进而会影响到用户的通信质量。

生成树协议STP(Spanning Tree Protocol)可以在提高可靠性的同时又能避免环路带来的各种问题

环路引起的问题

STP工作原理

非根交换机在选举根端口时分别依据该端口的 根路径开销、对端BID、对端PID和本端PID

在网段上抑制其他端口(无论是自己的还是其他设备的)发送BPDU报文的端口,就是该网段的指定端口。

每个网段都应该有一个指定端口,根桥的所有端口都是指定端口(除非根桥在物理上存在环路)

指定端口的选举也是首先比较累计根路径开销,累计根路径开销最小的端口就是指定端口。

如果累计根路径开销相同,则比较端口所在交换机的桥ID,所在桥ID最小的端口被选举为指定端口。

如果通过累计根路径开销和所在桥ID选举不出来,则比较端口ID,端口ID最小的被选举为指定端口。

网络收敛后,只有指定端口和根端口可以转发数据。

其他端口为预备端口,被阻塞,不能转发数据

只能够从所连网段的指定交换机接收到BPDU报文,并以此来监视链路的状态

阻塞预备端口(备用端口)

确定根端口、指定端口 剩余的非根端口、非指定端口统称为预备端口。 STP会对这些端口进行逻辑阻塞

STP报文格式

通过交换STP协议帧,建立和维护STP树 STP协议帧由交换机产生、发送、接收、处理 STP协议帧是一种组播帧,组播地址为01-80-c2-00-00-00


图中所示为STP的端口状态迁移机制,运行STP协议的设备上端口状态有5种: Forwarding:转发状态。端口既可转发用户流量也可转发BPDU报文,只有根端口或指定端口才能进入Forwarding状态。 Learning:学习状态。端口可根据收到的用户流量构建MAC地址表,但不转发用户流量。增加Learning状态是为了防止临时环路。 Listening:侦听状态。端口可以转发BPDU报文,但不能转发用户流量。 Blocking:阻塞状态。端口仅仅能接收并处理BPDU,不能转发BPDU,也不能转发用户流量。此状态是预备端口的最终状态。 Disabled:禁用状态。端口既不处理和转发BPDU报文,也不转发用户流量。

为了计算生成树,交换机之间需要交换相关的信息和参数

这些信息和参数被封装在BPDU(Bridge Protocol Data Unit)中。

BPDU有两种类型:配置BPDU和TCN BPDU。

配置BPDU包含了桥ID、路径开销和端口ID等参数。

STP协议通过在交换机之间传递配置BPDU来选举根交换机,以及确定每个交换机端口的角色和状态。

在初始化过程中,每个桥都主动发送配置BPDU。

在网络拓扑稳定以后,只有根桥主动发送配置BPDU

其他交换机在收到上游传来的配置BPDU后,才会发送自己的配置BPDU。

TCN BPDU是指下游交换机感知到拓扑发生变化时向上游发送的拓扑变化通知。

配置BPDU中包含了足够的信息来保证设备完成生成树计算,其中包含的重要信息如下:

根桥ID:由根桥的优先级和MAC地址组成,每个STP网络中有且仅有一个根。​根路径开销:到根桥的最短路径开销。​指定桥ID:由指定桥的优先级和MAC地址组成。

STP协议中包含一些重要的时间参数,这里举例说明如下:

Hello Time是指运行STP协议的设备发送配置BPDU的时间间隔,用于检测链路是否存在故障。

交换机每隔Hello Time时间会向周围的交换机发送配置BPDU报文,以确认链路是否存在故障。

当网络拓扑稳定后,该值只有在根桥上修改才有效。

Message Age:如果配置BPDU是根桥发出的,则Message Age为0。

否则,Message Age是从根桥发送到当前桥接收到BPDU的总时间,包括传输延时等。

实际实现中,配置BPDU报文每经过一个交换机,Message Age增加1。

Max Age是指BPDU报文的老化时间,可在根桥上通过命令人为改动这个值。

Max Age通过配置BPDU报文的传递,可以保证Max Age在整网中一致。

非根桥设备收到配置BPDU报文后,会将报文中的Message Age和Max Age进行比较:

如果Message Age小于等于Max Age,则该非根桥设备会继续转发配置BPDU报文。

如果Message Age大于Max Age,则该配置BPDU报文将被老化掉。

该非根桥设备将直接丢弃该配置BPDU,并认为是网络直径过大,导致了根桥连接失败。

STP拓扑变化

在稳定的STP拓扑里,非根桥会定期收到来自根桥的BPDU报文。

如果根桥发生了故障,停止发送BPDU报文,下游交换机就无法收到来自根桥的BPDU报文。

如果下游交换机一直收不到BPDU报文,Max Age定时器就会超时(Max Age的默认值为20秒)

从而导致已经收到的BPDU报文失效,此时,非根交换机会互相发送配置BPDU报文,重新选举新的根桥

根桥故障会导致50秒左右的恢复时间,恢复时间约等于Max Age加上两倍的Forward Delay收敛时间。

此例中,SWA和SWB使用了两条链路互连,其中一条是主用链路,另外一条是备份链路。

生成树正常收敛之后,如果SWB检测到根端口的链路发生物理故障,

则其Alternate端口会迁移到Listening、 Learning、Forwarding状态

经过2倍的Forward Delay后恢复到转发状态。

本例中,SWB与SWA之间的链路发生了某种故障(非物理层故障)

SWB因此一直收不到来自SWA的BPDU报文。

此时,SWB会认为根桥SWA不再有效,于是开始发送BPDU报文给SWC,通知SWC自己作为新的根桥。

SWC也会继续从原根桥接收BPDU报文,因此会忽略SWB发送的BPDU报文。

由于SWC的Alternate端口再也不能收到包含原根桥ID的BPDU报文。

其Max Age定时器超时后,SWC会切换Alternate端口为指定端口并且转发来自其根端口的BPDU报文给SWB。

SWB放弃宣称自己是根桥并开始收敛端口为根端口。

非直连链路故障后,由于需要等待Max Age加上两倍的Forward Delay时间

端口需要大约50秒才能恢复到转发状态。

在交换网络中,交换机依赖MAC地址表转发数据帧。

缺省情况下,MAC地址表项的老化时间是300秒。

如果生成树拓扑发生变化,交换机转发数据的路径也会随着发生改变

此时MAC地址表中未及时老化掉的表项会导致数据转发错误

因此在拓扑发生变化后需要及时更新MAC地址表项

拓扑变化过程中,根桥通过TCN BPDU报文获知生成树拓扑里发生了故障。

根桥生成TC用来通知其他交换机加速老化现有的MAC地址表项。

拓扑变更以及MAC地址表项更新的具体过程如下:

SWC感知到网络拓扑发生变化后,会不间断地向SWB发送TCN BPDU报文。

SWB收到SWC发来的TCN BPDU报文后,会把配置BPDU报文中的Flags的TCA位设置1

然后发送给SWC,告知SWC停止发送TCN BPDU报文。 SWB向根桥转发TCN BPDU报文。

SWA把配置BPDU报文中的Flags的TC位设置为1后发送

通知下游设备把MAC地址表项的老化时间由默认的300秒修改为Forwarding Delay的时间(默认为15秒)

最多等待15秒之后,SWB中的错误映射关系会被自动清除。

此后,SWB就能通过G0/0/2端口把从主机A到主机B的帧正确地进行转发。

STP的配置

STP模式

stp mode ?  #查询有哪些模式​stp mode stp    #使用stp模式

配置交换机优先级

stp priority 4096

通过修改交换机的优先级,可以配置交换机为根交换机

基于企业业务对网络的需求,一般建议手动指定网络中配置高、性能好的交换机为根桥。

可以通过配置桥优先级来指定网络中的根桥,以确保企业网络里面的数据流量使用最优路径转发。

stp priority priority命令用来配置设备优先级值。priority值为整数,取值范围为0到61440,

配置路径开销

stp pathcost-standard ?​stp cost 2000

华为X7系列交换机支持三种路径开销标准,以确保和友商设备保持兼容。

缺省情况下,路径开销标准为IEEE 802.1t

stp pathcost-standard { dot1d-1998 | dot1t | legacy }命令用来配置指定交换机上路径开销值的标准

验证配置

display stp

display stp命令用来检查当前交换机的STP配置。

命令输出中信息介绍如下

CIST Bridge参数标识指定交换机当前桥ID,包含交换机的优先级和MAC地址。

Bridge Times参数标识Hello定时器、Forward Delay定时器、Max Age定时器的值。

CIST Root/ERPC参数标识根桥ID以及此交换机到根桥的根路径开销。

总结

根桥产生故障后,其他交换机会被选举为根桥。那么原来的根桥恢复正常之后,网络又会发生什么变化呢?

如果生成树网络里面根桥发生了故障,则其它交换机中优先级最高的交换机会被选举为新的根桥。

如果原来根桥再次激活,则网络又会根据BID来重新选举新的根桥。

路径开销和根路径开销的区别是什么?

根路径开销是到根桥的路径的总开销,而路径开销指的是交换机端口的开销。

STP协议树配置的更多相关文章

  1. CCNA网络工程师学习进程(6)vlan相关协议的配置与路由器简单配置介绍

        前面已经介绍了大部分与vlan技术相关的交换机的协议的配置,更深层次的还有STP协议和以太网端口聚合技术,接着还会简单介绍一下路由器的基本应用.     (1)STP(Spanning-tre ...

  2. [转载]交换机STP协议

    注:之前做一个项目,测试部使用2个公司的交换机,H3C和H公司的,H公司的交换机是OEM H3C的交换机,正常来说两者使用没有区别. 但是使用中发现,如果设备的多个对外业务网口连接的交换机的聚合网口, ...

  3. STP协议与MSTP协议

    STP协议与MSTP协议 目录 一.STP概述 1.1.交换网络环路的产生 1.2.STP简介 二.生成树算法 2.1.生成树算法的步骤 2.2.网桥 ID 2.3.选择根端口 2.4.选择指定端口 ...

  4. 二层协议--STP协议总结

    生成树协议的技术实现与配置注意点 一.stp协议的用途 二.stp协议的运行机制 三.stp协议规范

  5. LLDP协议、STP协议 笔记

    参考: 数据链路层学习之LLDP 生成树协议 LLDP协议.STP协议 笔记 LLDP 提出背景: 随着网络技术的发展,接入网络的设备的种类越来越多,配置越来越复杂,来自不同设备厂商的设备也往往会增加 ...

  6. 分布式-信息方式-ActiveMQ支持的传输协议和配置

                             ActiveMQ支持的传输协议和配置■ Connector: ActiveMQ提供的,用来实现连接通讯的功能.包括: client-to-broker ...

  7. OSI模型第二层数据链路层-STP协议

    1.stp协议的由来. 在二层网络中,交换机起到了很重要的作用,如果有一台交换机出现故障会影响网络的使用,为了避免存在单点故障,在实际的二层链路中会采用链路冗余,也就是采用交换设备之间多条联络连接,即 ...

  8. 大型网站的 HTTPS 实践(三)——基于协议和配置的优化

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt389 1 前言 上文讲到 HTTPS 对用户访问速度的影响. 本文就为大家介 ...

  9. STP协议

    STP协议的作用: 第一, 可以避免网络环路和广播风暴. 二层数据包是没有TTL(time to live)的,如果不加以限制,可能会无限的传播下去.二层设备间如果存在环路,大量的广播包就可能导致广播 ...

随机推荐

  1. 纯javascript代码实现浏览器图片选择预览、旋转、批量上传

    工作中遇到的业务场景,和同事一起研究了下,主要是为了兼容IE版本 其实就是一些琐碎的知识点在网上搜集下解决方式,然后集成了下,主要有以下点: 1. IE input type=file的图片预览要用I ...

  2. android安全技术技能清单

    大部分android apk都是在裸奔.大部分android程序员,有一些懂得代码混淆,然而,这东西也不靠谱.除去第三方提供的服务的服务的话,大部分android apk就是在裸奔.不过,使用第三方的 ...

  3. 20155330 2016-2017-2 《Java程序设计》第八周学习总结

    20155330 2016-2017-2 <Java程序设计>第八周学习总结 教材学习内容总结 学习目标 了解NIO 会使用Channel.Buffer与NIO2 会使用日志API.国际化 ...

  4. 20155234 2016-2017-2 《Java程序设计》第5周学习总结

    20155234 2016-2017-2 <Java程序设计>第5周学习总结 教材学习内容总结 Java中所有错误都会被打包为对象,运用try.catch,可以在错误发生时显示友好的错误信 ...

  5. 20155325 2016-2017-2 《Java程序设计》第5周学习总结

    教材学习内容总结 Java中把正常流程放try块中,错误(异常)处理放catch块中. Error及其子类写程序不用处理,最多留个日志.因为这种错误Java应用程序本身是无力回复的. 在使用throw ...

  6. HDU 3449 Consumer (背包问题之有依赖背包)

    题目链接 Problem Description FJ is going to do some shopping, and before that, he needs some boxes to ca ...

  7. 动态SQL中变量赋值

    在动态SQL语句中进行变量的值绑定比较麻烦,这儿做个记录 declare @COUNT int,@sql nvarchar(max) set @sql = 'select @COUNT = count ...

  8. spring-boot-通用mapper

    数据源依赖 druid官方文档:https://github.com/alibaba/druid/wiki/常见问题 <dependency> <groupId>mysql&l ...

  9. ORA-00906 missing left parenthesis括号

    Oracle 建表报错:ORA-00906 missing left parenthesis括号    建表语句:create table test(id char,name varchar(1),s ...

  10. C++面试常见问题

    转载:https://zhuanlan.zhihu.com/p/34016871?utm_source=qq&utm_medium=social 1.在C++ 程序中调用被C 编译器编译后的函 ...