简易思维导图:
一、STP(802.1D)的概念
STP(Spanning Tree Protocol)是 生成树协议 的英文缩写,可应用于 计算机网络 中树形 拓扑结构 建立,主要作用是防止网桥网络中的 冗余链路 形成环路工作。. 但某些特定因素会导致STP失败,要排除故障可能非常困难,这取决于网络设计。生成树协议适合所有厂商的 网络设备 ,在配置上和体现功能强度上有所差别,但是在原理和应用效果是一致的。
二、网桥的四个选举
1.根网桥
根端口指定端口非指定端口(阻塞端口)
根网桥﹣一台交换机,在每一棵树形结构中有且仅有一台
周期的发送 BPDU ,计算整颗树形结构,保活和指挥整颗树的收敛
比较 BPDU 中的桥 ID = BID
BID =优先级默认327680-65535小优
若优先级相同,比较 MAC 地址数值小优
透明交换机无 MAC ,自然不支持生成树
支持 stp 的交换机,一定也支持 SVI 技术; SVI 技术可以让交换机配置 ip 地址,成为源或目标设备,自然出厂时携带 MAC 地址; stp 可以借用该 mac 地址 BID =网桥优先级+ MAC 地址
2.根端口﹣一个接口在每台非根网桥上,有且仅有一个接口成为根端口;该交换机本地离根网桥最近的接口,由于接收来自根的 BPDU ;也正常转发用户的数据;一不被阻塞
1、比较从根网桥发出的 BPDU ,通过该接口进入时的最小 cost 值
2、入向 cost 值相同时,比较对端(上级)设备的 BID ,小的对应接口为根端口3、若上级设备的 BID 相同,比较上级接口的 PID ,上级 PID 小,对应接口为根端口4、比较本地 PID
3.指定端口﹣一个接口在每一条两端均运行 stp 的物理链路上,有且仅有一个接口转发来自根的 BPDU ,也正常转发用户数据一不被阻塞
根端口对端为指定端口,根网桥上所有接口为指定端口
1、比较从根网桥发出的 BPDU ,通过该接口转出最小 cost 值
2、比较本地 BID ,小优
3、比较本地 PID ,小优
4、直接阻塞
非指定端口﹣以上所有角色选择完成后,剩余没有角色的接口全部成为非指定端口非指定端口为阻塞状态,-﹣不是 down ;可以收数据,但不转发任何流量主要在关注 BPDU 数据
PID =接口优先级0-255默认128小优+接口编号小优
三、接口状态
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.1D 缺点:
1、收敛慢
2、链路利用率低
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
PVST :cisco私有 基于vlan的生成树协议
在每个vlan内,存在一棵树,每个树的工作原理同802.1d一致;不同vlan的BPDU区别在于优先级;优先级=4096倍数+vlan id 人为仅可修改4096倍数备份,且只能修改为4096的整倍
仅支持 trunk干道封装为ISL(cisco私有封装)
六、PVST +
PVST + : 在PVST的基础,兼容802.1q的trunk封装;且设计了部分的加速;
端口加速(进入层连接用户的接口) 上行链路加速-针对直连检测 骨干加速—针对次优BPDU
上行链路加速仅在接入层设备上配置,因为配置后,该交换机将自动加大本地的网桥优先级;
在直连检测条件下阻塞接口将跳过30s,直接进入转发状态--上行链路加速
骨干加速所有交换机均可配置,针对接收到次优BPDU的阻塞端口可以跳过20s的hold time;
缺点:1、收敛慢(加速不彻底) 2、树多(仅cisco存在单独的芯片,友商无法负荷)
七、快速生成树
cisco的RSTP --- 基于vlan的快速生成树 - 一个vlan一棵树 pvst+的升级
公有RSTP(802.1w) --- 整个交换网络一棵树 802.1d的升级
快速的原理:
- 取消了计时器,而是在一个状态工作完成后,直接进入下一状态;
- 分段式同步,两台设备间逐级收敛;使用请求和同意标记;依赖标记位的第1和第6位
- BPDU的保活为6s;hello time 2s;
- 将端口加速(边缘接口)、上行链路加速、骨干加速集成了
- 兼容802.1d和PVST,但802.1d和PVST没有使用标记位中的第1-6位,故不能快速收敛;因此如果网络中有一台设备不支持快速收敛,那么其他开启快速收敛的设备也不能快速;
当tcn消息出现时,不需要等待根网桥的BPDU,就可以刷新本地的cam表;
切记:接口默认为半双工时,即便允许RSTP,依然基于慢速的802.1D算法来收敛;
[sw1]stp mode rstp
边缘接口---用于连接PC的接口,一旦被设定为边缘接口;将不再进行BPDU的发送,且不进行STP的收敛,直接为转发状态; 但若该接口收到了对端的BPDU,将失去边缘特性,重新正常收敛;
[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 switch
secondary 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 ? 修改接口cost
INTEGER<1-200000000> Port path cost
八、MSTP/MST/802.1S
含义:华为设备默认使用该协议
继承了快速生成树的基础; 将多个vlan放置于一个组内,基于每个组一棵生成树;
不同组间的BPDU中优先级= 4096倍数+组号
[r1]stp mode mstp
默认存在组0,且所有vlan默认处于该组;优先级= 32768+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 激活当前配置(必须配置该指令)
切记:若将创建某个组,但该组内的vlan,在本交换机上没有创建,同时没有为该vlan服务的接口;该组将没有任何信息;整个交换网络中所有设备的分组信息必须完全一致;
定义本地为组1 的主根,组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
https://blog.csdn.net/xieyunc/article/details/82785340