前言:STP生成树协议虽然能够解决环路的问题,但是存在着网络拓扑收敛较慢,无法适应网络拓扑结构的频繁变化等缺点,基于以上不足,IEEE在2001年发布的802.1w标准定义了RSTP(快速生成树协议)。
在STP中,交换机从初始状态到收敛状态至少需要30s,过程如下所示:
第一个15s(Listening->Learning):STP为了避免路由环路,必须等待足够长的时间(确保BPDU能够同步发送至全网各个节点)确保全网的状态全部确定才能进入转发。
第二个15s(Learning->Forwarding):在STP进入转发前还需根据收到的用户流量构建MAC地址表,等待计时器超时才能进入转发状态。
如图所示,在STP中,交换机连接PC端的链路进入转发状态也需要等待30s,事实上,交换机连接终端的这段链路是不会出现环路的,因此这段等待时间其实并不需要。
STP端口状态 | 行为 |
---|---|
Disabled | 不转发用户流量也不学习MAC地址 |
Blocking | 不转发用户流量也不学习MAC地址 |
Listening | 不转发用户流量也不学习MAC地址 |
Learning | 不转发用户流量但学习MAC地址 |
Forwording | 既转发用户流量又学习MAC地址 |
可以看出,上面三种状态从用户使用的角度来看都相同,却对应着不同的状态,反而增加了使用的难度。
RSTP定义了两种全新的端口角色:Backup Port(备份端口)和Alternate Port(预备端口)。
RSTP将原来的5中状态变为3种
STP端口状态 | RSTP端口状态 | 端口状态对应的行为 |
---|---|---|
Disabled | Discarding | 如果不转发用户流量也不学习MAC地址 |
Blocking | ||
Listening | ||
Learning | Learning | 不转发用户流量但学习MAC地址 |
Forwording | Forwording | 既转发用户流量也学习MAC地址 |
P/A机制
Proposal/Agreement机制,其目的是使一个指定端口尽快进入Forwarding状态。
P/A机制要求两台交换设备之间链路必须是点对点的全双工模式。一旦P/A协商不成功,指定端口的选择就需要等待两个Forward Delay,协商过程与STP一样。
事实上对于STP,指定端口的选择可以很快完成,主要的速度瓶颈在于:为了避免环路,必须等待足够长的时间,使全网的端口状态全部确定,也就是说必须要等待至少两个Forward Delay,所有端口才能进行转发。
特点:使用来回确认机制和同步变量机制,就无需依靠计时器来保证无环。
P/A协商的过程:
P/A机制的具体做法
阶段一:设备刚刚启动,RSTP协议刚刚启用,所有交换机都认为自己是根桥,向其他交换机发送P置位的BPDU,并把发送P消息的端口变成DP口,同时接口处在Discarding状态。
阶段二:交换机SWA收到SWB和SWC的P消息会置之不理,因为他的桥优先级最高。交换机SWB和SWC收到SWA的P消息后,由于认同SWA是最优的根桥,会根据P/A协商流程回复A消息,并把发送端口变成RP端口,同时接口处在Forwarding状态。
阶段三:SWA与SWB,SWA与SWB的P/A协商已经完成,接下来是SWB和SWC的P/A协商。
SWB和SWC的协商过程如下:
针对于前面提到的STP的问题二,在RSTP中,当SWA与SWC之间的直连链路down后,SWC上的AP端口会迅速切换成RP端口并进入转发状态。
若SWA与SWB之间的直连链路down掉,SWC上的AP端口会快速切换成DP端口并进入转发状态。
在RSTP中,交换机连接终端的链路可以立即进入转发状态。当交换机上的改接口接收到BPDU后,就会失去边缘端口的属性,成为普通的STP口,并重新参与生成树的计算。
判断拓扑变化的唯一标准:一个非边缘端口迁移到Forwording状态。
一旦检测到拓扑发生变化,将进行如下处理:
应用场景: 防止有人伪造RST BPDU恶意攻击交换设备,当边缘端口接收到该报文时,会自动设置为非边缘端口,并重新进行生成树计算,引起网络震荡。
实现原理: 配置BPDU保护功能后,如果边缘端口收到BPDU报文,边缘端口将会被立即关闭。
应用场景: 由于维护人员的错误配置或网络中的恶意攻击,网络中合法根桥有可能会收到优先级更高的RST BPDU,使得合法根桥失去根地位,从而引起网络拓扑结构的错误变动。
实现原理: 一旦启用Root保护功能的指定端口收到优先级更高的RST BPDU时,端口状态将进入Discarding状态,不再转发报文。在经过一段时间,如果端口一直没有再收到优先级较高的RST BPDU,端口会自动恢复到正常的Forwarding状态。(Root保护功能只能在指定端口上配置生效。)
交换机在接收到TC-BPDU报文后,会执行MAC地址表项的删除操作。如果有人伪造TC-BPDU报文恶意攻击交换机时,交换机短时间内会收到很多TC-BPDU报文,频繁的删除操作会给设备造成很大的负担,给网络的稳定带来很大隐患。
启用防TC-BPDU报文攻击功能后,在单位时间内,RSTP进程处理TC类型BPDU报文的次数可配置(缺省的单位时间是2秒,缺省的处理次数是3次)。如果在单位时间内,RSTP进程在收到TC类型BPDU报文数量大于配置的阈值,那么RSTP进程只会处理阈值指定的次数;对于其他超出阈值的TC类型BPDU报文,定时器到期后,RSTP进程只对其统一处理一次。这样可以避免频繁的删除MAC地址表项,从而达到保护交换机的目的。
[SWA]stp enable #全局开启stp
[SWA]stp mode rstp #设置stp模式为rstp
[SWA]stp root primary #将SWA设为根桥
在SWB上的配置
[SWB]stp enable
[SWB]stp mode rstp
[SWB]stp bpdu-protection #开启BPDU保护,配合边缘端口使用
[SWB]interface GigabitEthernet 0/0/4
[SWB-GigabitEthernet0/0/4]stp edged-port enable #将连接PC的端口设置为边缘端口
SWC与SWB配置一致就不再显示了。
检验配置:
在SWA上查看生成树情况:
在SWB上查看生成树情况:
在SWC上查看生成树情况:
可以看出来,SWC上的g0/0/4端口处于DISCARDING状态,即处于堵塞状态,消除了网络中的环路。