一、STP简述
STP是一个用于局域网中消除环路的协议。
生成树: 在一个二层交换网络中,生成一棵树型结构,逻辑的阻塞部分接口,使得从根到所有的节点仅存在唯一的路径;当最佳路径故障时,自动打开部分阻塞端口,来实现线路备份的作用;生成树在生成过程中,应该尽量的生成一棵星型结构,且最短路径树;
原理:通过允许stp算法,阻塞特定的接口实现冗余无环的网络
企业网三层架构—>冗余—>线路冗余—>二层桥接环路
二层桥接环路就导致了很多问题:
- 广播风暴
- MAC地址表翻滚(在一台交换机上,同一个MAC地址只能映射唯一的接口;但同一个接口可以映射多个不同的MAC地址)
- 同一数据帧的重复拷贝
这三个问题导致的后果就是设备工作过载,导致重启保护。
基于这些问题,就有了生成树协议。
二、生成树的原理
在一个二层交换网络中,逻辑的阻塞部分接口;形成从源到目标唯一路径(即使得从根到所有的节点仅存在唯一的路径);当最佳路径故障时,自动疏通被堵塞的部分接口,来继续网络通讯;实现线路备份
注意: 阻塞是逻辑阻塞,不是物理阻塞,所以不是shutdown
三、工作过程(选举过程)
1. 根网桥
对比BPDU中的桥ID: 桥ID= 网桥优先级 + MAC地址(本地背板池)
交换机作为网桥设备时,关注终端设备发送的数据帧中的MAC地址;但交换机本地无MAC;
需要运行STP协议的交换机,必须在出厂时由厂家进行MAC的写入-存储于交换机的背板地址池中
若交换的背板地址池中MAC地址为多个,将选择数值最小的地址来进行选举
先比较网桥优先级(0-65535,默认32768),小优;若优先级一致,比较MAC地址,数值小优;
注明: 在每一棵生成树实例中,有且仅有一台交换机作为根桥;负责发送BPDU,计算和指挥整个树的收敛;作为树形结构的根部,交换网络部分的中心节点。
2. 根端口
在每台非根网桥上,有且仅有一个接口;本地离根网桥最近的接口(最短、星型),接收来自根网桥的BPDU,转发用户的流量(该接口不阻塞)
规则:
- 比较从根网桥发出后,通过该接口进入时最小的cost值
- 入向cost值相同,比较该接口对端设备的BID,小优
- 对端BID也相同,比较该接口对端设备的接口的PID;先优先级小,若优先级一致,编号小
- 连对端PID也相同,比较本地PID,小优
PID=端口ID = 接口优先级(0-240,默认128 小优)+ 接口编号 先比较优先级,小优;若优先级相同比较接口编号,数值小优
3. 指定端口
指定端口 ---- 在每一段存在STP的物理链路上,有且仅有一个;转发来自根网桥的BPDU,同时可以转发用户流量(不阻塞);默认根网桥上所有接口为指定端口;
- 比较从根网桥发出后,通过该接口进入这段链路时的cost值最小(出向)
- 若出向cost值相同,必须本地的BID,小优;
- 本地BID相同,比较本地的PID;
- 本地PID,相同,直接阻塞该端口;
4. 非指定端口
非指定端口 ---- 以上所有角色选举完成后,剩余各个接口的角色;该接口处于阻塞状态;
接口阻塞是逻辑上的,并不是接口被关闭;该接口处于可以接收到数据,但不进行转发的状态
四、生成树的类型
1. 802.1D(标准生成树)
一个交换网络内仅存在一棵生成树实例
接口状态:
down:没有BPDU收发,一旦可以进行BPDU收发进入下一状态
侦听:强制15s;所有交换机进行BPDU收发,选举所有角色;接口角色为非指定端口直接进入阻塞状态;若为指定端口和根端口进入下一状态;
学习:强制15s; 指定端口和根端口学习所有接口连接设备的MAC地址,生成MAC表;之后进入下一状态;
转发:指端端口和根端口进入,可以转发用户报文;
阻塞:逻辑阻塞;
注:只有到接口进入到转发状态后,才能为用户转发数据报文,之前的30s不能转发任何数据
收敛时间:
初次收敛 — 30s = 15侦听+15s学习
结构变化:
存在直连检测:本地存在阻塞端口,若其他端口断开,该阻塞端口马上进入15是侦听(选举);结果若为启用,那么将再进入15s学习—总30s
没有直连检测:本地不存在阻塞端口,若某个端口断开,将发送次优BPDU(以本地为根)给其他邻居交换机,其他交换机无视该数据,进行20s hold time计时,到时时阻塞接口进入15s侦听,15s学习=总50s
802.1D 缺点:
- 收敛慢
- 链路利用率低
[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
2. PVST
PVST 基于VLAN的生成树协议依然沿用了802.1D的运算规则,区别在于,一个VLAN中存在一棵树
PVST cisco私有 基于vlan的生成树协议
在每个vlan内,存在一棵树,每个树的工作原理同802.1d一致;不同vlan的BPDU区别在于优先级;
优先级=4096倍数+vlan id 人为仅可修改4096倍数备份,且只能修改为4096的整倍
仅支持 trunk干道封装为ISL(cisco私有封装)
可以将不同vlan的根网桥放置于不同的汇聚层设备,实现在不同vlan 中阻塞不同的链路;
最终所有链路均被利用,互为备份,提高链路的利用率;
(换句话说,一棵树堵塞的部分给另一个棵树用,这样就提高了链路的利用率)
优点: 分流,使用所有物理链路----提高利用率
缺点:
- 收敛慢
- 树多 cisco 设备中存在一块独立的stp专用芯片(硬件解决)
- 纯私有协议—近支持isl -------(Cisco专用的trunk上封装vlan id 的标准 ,另外一个标准802.1q)
3. PVST+
在PVST的基础,兼容802.1q的trunk封装;且设计了部分的加速
端口加速(进入层连接用户的接口) 上行链路加速-针对直连检测 骨干加速—针对次优BPDU
上行链路加速仅在接入层设备上配置,因为配置后,该交换机将自动加大本地的网桥优先级;
在直连检测条件下阻塞接口将跳过30s,直接进入转发状态–上行链路加速
骨干加速所有交换机均可配置,针对接收到次优BPDU的阻塞端口可以跳过20s的hold time;
缺点:
- 收敛慢(加速不彻底)
- 树多(仅cisco存在单独的芯片,友商无法负荷)
优点: 利用率(一个vlan一棵树) 部分加速 兼容802.1q
4. 快速生成树
cisco的RSTP ---- 基于vlan的快速生成树 — 一个vlan一棵树 pvst+的升级
公有RSTP(802.1w) — 整个交换网络一棵树 802.1d的升级
快速的原理:
1、取消了计时器,而是在一个状态工作完成后,直接进入下一状态;
2、分段式同步,两台设备间逐级收敛;使用请求和同意标记;依赖标记位的第1和第6位
3、BPDU的保活为6s;hello time 2s;
4、将端口加速(边缘接口)、上行链路加速、骨干加速集成了
5、兼容802.1d和PVST,但802.1d和PVST没有使用标记位中的第1-6位,故不能快速收敛;因此如果网络中有一台设备不支持快速收敛,那么其他开启快速收敛的设备也不能快速;
当tcn消息出现时,不需要等待根网桥的BPDU,就可以刷新本地的cam表;
切记:接口默认为半双工时,即便允许RSTP,依然基于慢速的802.1D算法来收敛
[sw1]stp mode rstp // 边缘接口;
用于连接PC的接口,一旦被设定为边缘接口;将不再进行BPDU的发送,且不进行STP的收敛,直接为转发状态; 但若该接口收到了对端的BPDU,将失去边缘特性,重新正常收敛;
[sw1]stp priority ? // 修改网桥优先级
[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
5. 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