生成树协议STP详解

生成树协议是什么?

定义 :生成树协议(Spanning Tree Protocol,简称STP)是一种数据链路层协议,主要用于防止交换机冗余链路产生的环路 ,确保以太网中无环路的逻辑拓扑结构,从而避免广播风暴和大量占用交换机资源

为什么需要STP协议

网络中存在环路是造成广播风暴最常见的原因。

下面以ARP报文为例,说明环路会存在什么问题,环路如何造成广播风暴

ARP造成网络风暴

在一个局域网(同一网段)中,设备之间的通信首先要通过ARP报文获取目的IP对应的MAC地址。首先交换机会查找ARP缓存表,(ARP缓存表存的是IP地址和MAc地址的对应关系,且有老化时间,过一段时间会消失):

  • 如果ARP缓存表中有目的交换机的MAC,直接发送数据包
  • 如果ARP缓存表中没有目的交换机的MAC,发送ARP请求报文

原理

假设网络连接图如上图,形成了环路。PCA要与PCB通信,PCA首先发送ARP报文(广播),每个设备收到报文之后都会进行泛洪(向入端口之外的端口发ARP广播包)。

  • PCB收到了ARP请求(来自SW3),并会进行单播回复(这个回复是正常的,不会形成风暴)。
  • 但是,SW2 和 SW3 同时通过链路B向对方发送了一个ARP请求的副本!然后就会一直循环在这个圈里打转~~

ARP报文包括以太网帧头和ARP报文数据。网上有很多资料,就不详细展开了,需要注意:

  • 以太网帧头的目的MAC用的全F广播,ARP报文数据中的MAC地址用全0填充。
  • 以太网帧头类型字段是0X0806表示ARP。

STP如何解决广播风暴问题

核心思路:把网络中的环变成一个树,因为树形结构是没有环路的。

BPDU(网桥协议数据单元)

BPDU封装在以太网帧中,包含下面的一些关键信息,后续交换机之间就是通过这个报文来确定阻断哪条路的:

  • 根桥ID:当前根桥的标识(由桥ID和MAC地址组成)。
  • 根路径成本:从发送BPDU的交换机到根桥的累计路径成本。
  • 发送桥ID:发送此BPDU的交换机的ID。
  • 端口ID:发送此BPDU的端口的ID。
  • 计时器:Hello时间、转发延迟、最大生存时间等。

原理

选举根桥

在所有的交换机中选择一个交换机作为根桥,建议手动配置。当所有交换机都启动STP后,都认为自己是根桥,然后发送BPDU报文。一轮轮比较确定根桥,值越小越优

复制代码
桥ID > MAC地址

选举根端口

每台非根桥按照到达根桥路径成本最小的原则,选取根端口。还是根据一轮一轮的比较来确定,值越小越优。比较顺序为:

arduino 复制代码
Root Path Cost > Bridge ID(发送者桥ID)> Port ID(发送者端口ID)> 本地端口ID(不在BPDU报文中)

选举指定端口

  1. 连接在同一个网段上的交换机,互相比较谁到达根桥的路径成本更小。
  2. 路径成本最小的那台交换机,它连接这个网段的端口就成为指定端口。
  3. 如果路径成本相同,则比较交换机的桥ID(小的优)。

阻塞

既不是根端口,也不是指定端口的,阻塞!

配置示例(华为)

通常配置的时候都是直接指定根桥,再指定一个备份根桥。防止他自己选举选到性能较差的交换机作为根桥。配置比较简单,放个链接:

配置STP功能示例 - S600-E系列交换机 典型配置案例 - 华为

相关推荐
pythonchashaoyou3 小时前
静态住宅ip是什么,静态住宅IP选型全解
网络·网络协议·tcp/ip
科技块儿6 小时前
如何定期向监管部门报送IP属地统计报表?
网络·网络协议·tcp/ip
win x6 小时前
UDP Socket
网络·网络协议·udp
小李独爱秋7 小时前
计算机网络经典问题透视:RTS/CTS是强制使用还是选择使用?
网络协议·计算机网络·网络安全·信息与通信·信号处理
hoududubaba7 小时前
ORAN C平面传输和基本功能——C平面消息的ACK/NACK过程
网络·网络协议
坐怀不乱杯魂7 小时前
Linux 网络 - HTTP -cookie session
网络·网络协议·http
小李独爱秋7 小时前
计算机网络经典问题透视:无线局域网MAC协议中的SIFS和DIFS究竟是什么?
网络协议·计算机网络·macos·网络安全·信息与通信·信号处理
惊讶的猫7 小时前
短轮询,长轮询和websocket
网络·websocket·网络协议
津津有味道18 小时前
易语言TCP服务端接收刷卡数据并向客户端读卡器发送指令
服务器·网络协议·tcp·易语言
酣大智18 小时前
接口模式参数
运维·网络·网络协议·tcp/ip